JRT实体视图查询

JRT的设计目标就是多数据库支持,对于爬行周边数据提供DolerGet解决爬取多维数据问题。但是对于通过父表字段筛选子表数据就不能通过DolerGet取数据了,因为查询到的父表数据没有子表数据的ID。

比如下面表:

我需要按登记号查询这个登记号的报告数据,如果先查询父表数据,再循环一个个查子数据,那么数据多了之后需要交互数据库太多了,就会慢,这种情况就需要级联查询,来减少交互次数。而父表数据也拿不到子表的ID,因而不能利用DolerGet特性。
在这里插入图片描述

在这里插入图片描述

所以需要ORM来支持视图查询,常规的一般是提供SQL语句执行的api直接执行SQL。但是这样跨数据库就不能无缝支持了,为此需要提供一种独立于数据库的视图查询方法。

首先定义实体来描述级联关系
在这里插入图片描述
然后定义一个基类来存储视图描述数据
在这里插入图片描述
然后抽取一个所有视图实体要实现的接口供ORM得到视图描述信息
在这里插入图片描述
定义一个注解来标记视图
在这里插入图片描述

定义视图
在这里插入图片描述
ORM根据视图注解调用获取视图信息接口得到信息后组装视图SQL

/*** 构造视图的SQL语句* @param factory* @param tableInfo* @param model* @throws Exception*/private static void MakeViewTableInfo(IDbFactory factory,TableInfo tableInfo,Object model) throws Exception{if(model==null){model=tableInfo.ModelClass.getConstructor().newInstance();}BaseViewInterface base=(BaseViewInterface)model;BaseView view=base.GetView();StringBuilder tmpSb=new StringBuilder();tmpSb.append("(select ");String fromSql=" from ";boolean hasAddCol=false;//得到视图列信息Field[] viewFields = tableInfo.ModelClass.getDeclaredFields();HashMap<String,Field> viewFiledMap=new HashMap<>();for(Field f:viewFields){viewFiledMap.put(f.getName(),f);}//记录已经添加的列,避免重复添加HashMap<String,Boolean> hasAddColMap=new HashMap();for(int i=0;i<view.TableList.size();i++){ViewModelDto one=view.TableList.get(i);if(one.LinkType==null||one.LinkType.isEmpty()){one.LinkType="left";}String oneModelName=one.ModelClass.getSimpleName();if(i==0) {fromSql += " " + factory.DealTableName(GetTableName(one.ModelClass)) + " "+oneModelName+" ";}else{fromSql += one.LinkType+" join " + factory.DealTableName(GetTableName(one.ModelClass)) + " " + oneModelName+" on "+oneModelName+"."+one.LinkCurCol+"="+one.PerModelClass.getSimpleName()+"."+one.LinkPerCol+" ";}//得到列信息Field[] declaredFields = one.ModelClass.getDeclaredFields();//指定了查询列HashMap<String,Boolean> colMap=new HashMap<>();if(one.Cols!=null&&!one.Cols.isEmpty()){String [] colArr=one.Cols.split(",");for(String col:colArr){if(col.isEmpty()){continue;}colMap.put(col,true);}}//得到查询列for (int j = 0; j < declaredFields.length; j++) {if(colMap.size()>0&&!colMap.containsKey(declaredFields[j].getName())){continue;}String colName=declaredFields[j].getName();if(!viewFiledMap.containsKey(colName)){continue;}Field colFile=viewFiledMap.get(colName);String transName="";if(one.ColTrans!=null&&one.ColTrans.containsKey(colName)){transName=" as "+factory.DealPropertyName(one.ColTrans.get(colName));}//避免重复列名if(hasAddColMap.containsKey(colName)){continue;}JRT.DAL.ORM.Common.ColumnInfo col = new JRT.DAL.ORM.Common.ColumnInfo();FrekeyAttribute fk = colFile.getAnnotation(FrekeyAttribute.class);col.FkInfo = fk;col.Name = colName;col.ColType = colFile.getType();col.FieldInfo = colFile;tableInfo.ColList.add(col);//特殊列Annotation dateAttribute = colFile.getAnnotation(DateAttribute.class);//日期0,时间1,布尔2if (dateAttribute != null) {tableInfo.SpCol.put(col.Name, 0);}Annotation timeAttribute = colFile.getAnnotation(TimeAttribute.class);if (timeAttribute != null) {tableInfo.SpCol.put(col.Name, 1);}Annotation boolAttribute = colFile.getAnnotation(BoolAttribute.class);if (boolAttribute != null) {tableInfo.SpCol.put(col.Name, 2);}//根据IdAttribute注解得到表ID字段IdAttribute id = colFile.getAnnotation(IdAttribute.class);if (id != null) {JRT.DAL.ORM.Common.IdInfo idInfo = new JRT.DAL.ORM.Common.IdInfo();idInfo.Key = col.Name;idInfo.Value = col.Value;tableInfo.ID = idInfo;}if(hasAddCol==false) {tmpSb.append(oneModelName + "." + factory.DealPropertyName(col.Name));}else{tmpSb.append("," + oneModelName + "." + factory.DealPropertyName(col.Name));}hasAddColMap.put(col.Name,true);hasAddCol=true;}}tmpSb.append(" "+fromSql+")");tableInfo.VewSql=tmpSb.toString();}

视图实体和正常单表实体一样查询数据
在这里插入图片描述
测试效果
在这里插入图片描述

这样基于DolerGet和视图查询开发业务就可以游刃有余了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3249656.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

【linux】服务器安装NVIDIA驱动

【linux】服务器安装NVIDIA驱动 【创作不易&#xff0c;求点赞关注收藏】&#x1f600; 文章目录 【linux】服务器安装NVIDIA驱动一、关闭系统自带驱动nouveau二、下载英伟达驱动三、安装英伟达驱动1、禁用X服务器和相关进程2、在TTY终端安装驱动3、验证是否安装成功4、重新启…

接口开发:Orcal数据库的批量修改sql

场景&#xff1a;在日常的CURD中一定会用到批量修改。在我们的项目中&#xff0c;使用的数据库是Orcal&#xff0c;由于之前基本都是使用Mysql的&#xff0c;使用的sql语句也基本都是用mysql的。但是在这次的接口编写时用mysql的批量修改出了问题&#xff0c;刚开始我还以为是写…

源码分析SpringCloud Gateway如何加载断言(predicates)与过滤器(filters)

我们今天的主角是Gateway网关&#xff0c;一听名字就知道它基本的任务就是去分发路由。根据不同的指定名称去请求各个服务&#xff0c;下面是Gateway官方的解释&#xff1a; Spring Cloud Gateway&#xff0c;其他的博主就不多说了&#xff0c;大家多去官网看看&#xff0c;只…

WDL(Wide Deep Learning for Recommender Systems)——Google经典CTR预估模型

一、文章简介 Wide & Deep Learning for Recommender Systems这篇文章介绍了一种结合宽线性模型和深度神经网络的方法&#xff0c;以实现推荐系统中的记忆和泛化。这种方法在Google Play商店的应用推荐系统中进行了评估&#xff0c;展示了其显著的性能提升。 推荐系统中的…

食堂采购系统开发:从需求分析到上线实施的完整指南

本篇文章&#xff0c;笔者将详细介绍食堂采购系统从需求分析到上线实施的完整过程&#xff0c;旨在为开发团队和管理者提供一个系统化的指南。 一、需求分析 1.用户需求 常见的需求包括&#xff1a; -采购计划管理 -供应商管理 -库存管理 -成本控制 -报表生成 2.系统功…

RK3568笔记四十:设备树

若该文为原创文章&#xff0c;转载请注明原文出处。 一、介绍 设备树 (Device Tree) 的作用就是描述一个硬件平台的硬件资源&#xff0c;一般描述那些不能动态探测到的设备&#xff0c;可以被动态探测到的设备是不需要描述。 设备树可以被 bootloader(uboot) 传递到内核&#x…

CentOS6minimal安装nginx-1.26.1.tar.gz 笔记240718

CentOS6安装新版nginx 240718, CentOS6.1-minimal 安装 nginx-1.26.1.tar.gz 下载 nginx-1.26.1.tar.gz 的页面 : https://nginx.org/en/download.html 下载 nginx-1.26.1.tar.gz : https://nginx.org/download/nginx-1.26.1.tar.gz CentOS6.1已过期, 给它更换yum源, 将下面…

SpringCloud------Sentinel(微服务保护)

目录 雪崩问题 处理方式!!!技术选型 Sentinel 启动命令使用步骤引入依赖配置控制台地址 访问微服务触发监控 限流规则------故障预防流控模式流控效果 FeignClient整合Sentinel线程隔离-------故障处理线程池隔离和信号量隔离​编辑 两种方式优缺点设置方式 熔断降级-----…

简述乐观锁和悲观锁——Java

悲观锁和乐观锁 悲观就是任何事都认为会往坏处发生&#xff0c;乐观就是认为任何事都会往好处发生。 打个比方&#xff0c;假如一个公司里只有一台打印机&#xff0c;如果多个人同时打印文件&#xff0c;可能出现混乱的问题&#xff0c;他的资料打印在了我的资料上&#xff0…

【视频讲解】神经网络、Lasso回归、线性回归、随机森林、ARIMA股票价格时间序列预测|附代码数据

全文链接&#xff1a;https://tecdat.cn/?p37019 分析师&#xff1a;Haopeng Li 随着我国股票市场规模的不断扩大、制度的不断完善&#xff0c;它在金融市场中也成为了越来越不可或缺的一部分。 【视频讲解】神经网络、Lasso回归、线性回归、随机森林、ARIMA股票价格时间序列…

Unity动画系统(4)

6.3 动画系统高级1-1_哔哩哔哩_bilibili p333- 声音组件添加 using System.Collections; using System.Collections.Generic; using UnityEngine; public class RobotAnimationController : MonoBehaviour { [Header("平滑过渡时间")] [Range(0,3)] publ…

AI智能名片S2B2C商城小程序在社群去中心化管理中的应用与价值深度探索

摘要&#xff1a;随着互联网技术的飞速发展&#xff0c;社群经济作为一种新兴的商业模式&#xff0c;正逐渐成为企业与用户之间建立深度连接、促进商业增长的重要途径。本文深入探讨了AI智能名片S2B2C商城小程序在社群去中心化管理中的应用&#xff0c;通过详细分析社群去中心化…

科普文:多线程如何使用CPU缓存?

一、前言 计算机的基础知识聊的比较少&#xff0c;但想要更好的理解多线程以及为后续多线程的介绍做铺垫&#xff0c;所以有必要单独开一篇来聊一下 CPU cache。 二、CPU 前面有一篇文章关于 CPU是如何进行计算 感兴趣的同学&#xff0c;可以先移步了解一下&#xff0c;不了…

连接Redis异常:JedisMovedDataException

redis.clients.jedis.exceptions.JedisMovedDataException: MOVED 5798 192.168.187.138:6379 在使用JAVA API连接redis的时候&#xff0c;出现了异常&#xff1a; 问题的原因 JAVA API实现是redis集群实现方式&#xff0c;而在配置文中就配置的是单结点的方式。 Moved表示使…

从人工巡检到智能防控:智慧油气田安全生产的新视角

一、背景需求 随着科技的飞速发展&#xff0c;视频监控技术已成为各行各业保障安全生产、提升管理效率的重要手段。特别是在油气田这一特殊领域&#xff0c;由于其工作环境复杂、安全风险高&#xff0c;传统的监控方式已难以满足实际需求。因此&#xff0c;基于视频监控AI智能…

NLP教程:1 词袋模型和TFIDF模型

文章目录 词袋模型TF-IDF模型词汇表模型 词袋模型 文本特征提取有两个非常重要的模型&#xff1a; 词集模型&#xff1a;单词构成的集合&#xff0c;集合自然每个元素都只有一个&#xff0c;也即词集中的每个单词都只有一个。 词袋模型&#xff1a;在词集的基础上如果一个单词…

springcolud学习04Ribbon

Ribbon Ribbon是一个用于构建分布式系统的开源项目&#xff0c;最初由Netflix开发。它是一个基于HTTP和TCP客户端负载均衡器&#xff0c;用于将客户端的请求分发到多个服务实例上&#xff0c;以提高系统的性能和可靠性。Ribbon提供了许多负载均衡算法和配置选项&#xff0c;可…

maven内网依赖包编译报错问题的一种解决方法

背景 外网开发时可以连接互联网&#xff0c;所以编译没有什么问题&#xff0c;但是将数据库、代码、maven仓库全部拷贝到内网&#xff0c;搭建内网环境之后&#xff0c;编译失败。 此依赖包的依赖层级图 maven镜像库配置使用拷贝到内网的本地库&#xff0c;配置如下&#xff…

WebRTC音视频-前言介绍

目录 效果预期 1&#xff1a;WebRTC相关简介 1.1&#xff1a;WebRTC和RTC 1.2&#xff1a;WebRTC前景和应用 2&#xff1a;WebRTC通话原理 2.1&#xff1a;媒体协商 2.2&#xff1a;网络协商 2.3&#xff1a;信令服务器 效果预期 1&#xff1a;WebRTC相关简介 1.1&…

24位动态信号采集卡8路同步音频震动信号采集IEPE采集卡USB8814

24位动态信号采集卡 音频震动信号采集USB8814实测演示 品牌&#xff1a;阿尔泰科技 产品概述&#xff1a; USB8814 是一款为测试音频和振动信号而设计的高精度数据采集卡。该板卡提供 8 路同步模拟输 入通道&#xff0c;24bit 分辨率&#xff0c;单通道采样速率zui高 204.8kSP…