(二十五)JDBC多表查询
java易错点
数组初始化的时候,可以用
{}赋值,初始化以后,只能用new Object[]赋值了 ;set集合的add()和addAll()方法,前者将集合作为整体保存到集合中,后者将集合中的每一个元素保存到集合中;
一对多 VS 多对一 VS 多对多
表的关系,具体是选择 一对多 、 多对一 还是 多对多,在查询显示的时候,怎么显示,主要看我们的实际需求,显示一方的时候,是否需要显示另一方;
比如员工和部门的例子,部门表和员工表,就不应该选择 双向绑定 关系;因为在展示部门的时候,不需要将其下面的员工全部显示出来的;
还有一点,就是多的一方数据很多,我们需要采用分页的技术进行显示;
一对多 尽量避免,除非非要使用(比如订单)。使用的时候要注意数据量问题;
级联
·如果没设置级联,则需要先将依赖表的外键列置空。才能删除被依赖表 ;
·设置了级联 (当删除被依赖表的记录时候,会自动将依赖表的外键列置空 )
set null :当外键依赖被删除的时候,会自动将外键列置空 ;
cascard : 当外键依赖被删除的时候 ,外键所在记录也会被删除 ;
多表增删改
·一对多 (部门与员工)
其实也可以使用面向对象的思想设计表,但是我们查找多方的时候,注意下,是否需要查找 ;
·多对多 (学生与老师)
查询老师的学生,真正的多表操作 ,先去中间表查询该老师有哪些学生id,再去学生表,查找对应id的学生;
·查询:(无论什么关系。多对多、一对多。。。我们在设计对象的时候,在少的一方,里面都设计上集合存储多的一方,但是查询的时候,根据情况绝对是否真的要查询 ;)
·一对多:不需要多表查询;显示与不显示多的一方,只是sql条数的问题 ;
·多对多:如果需要显示多方的数据,则需要多表查询;
·查询的时候,如果不要求显示多的一方,则直接单表查询出少的一方;
·如果明确需要一并显示多的一方,则继续查询,查询的逻辑,就写在查询之前类的dao里面;
比如:老师与学生 ;在查询老师的时候,如果需要需要显示老师对应的学生,则继续在老师的Dao里面继续写逻辑 ;
·插入:
·一对多:可以在少的一方的dao层插入,也可以在多方dao层导入 ;
·多对多:一般写在少的一方的dao层里面,更新关系表,也写在这,减少代码量。
---------------------------------------------------------------------------------
| |
| 备注:对于设计到多个表,我也不太清楚dao层是如如何设计的;2018年6月14日23:02:22 |
| |
---------------------------------------------------------------------------------
多对多表设计语句(学生老师)
// 学生表
create table student
(
id int ,
name varchar(10)
);
// 老师表
create table teacher
(
id int,
name varchar(10),
money float
) ;
// 中间表,设置了级联
create table teacher_student
(
teacher_id int,
student_id int,
constraint teacher_id_FK foreign key(teacher_id) references teacher(id) on delete cascade,
constraint student_id_FK foreign key(student_id) references student(id) on delete cascade
);
(二十五)JDBC多表查询的更多相关文章
- 夯实Java基础(二十五)——JDBC使用详解
1.JDBC介绍 JDBC的全称是Java Data Base Connectivity(Java数据库连接).是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问(例如MyS ...
- Java进阶(二十五)Java连接mysql数据库(底层实现)
Java进阶(二十五)Java连接mysql数据库(底层实现) 前言 很长时间没有系统的使用java做项目了.现在需要使用java完成一个实验,其中涉及到java连接数据库.让自己来写,记忆中已无从搜 ...
- FreeSql (十九)多表查询
多表查询,常用的有联表 LeftJoin/InnerJoin/RightJoin ,这三个方法在上篇文章已经介绍过. 除了联表,还有子查询 Where Exists,和 Select 子表: IFre ...
- FreeSql (二十五)延时加载
FreeSql 支持导航属性延时加载,即当我们需要用到的时候才进行加载(读取),支持1对1.多对1.1对多.多对多关系的导航属性. 当我们希望浏览某条订单信息的时候,才显示其对应的订单详细记录时,我们 ...
- Bootstrap <基础二十五>警告(Alerts)
警告(Alerts)以及 Bootstrap 所提供的用于警告的 class.警告(Alerts)向用户提供了一种定义消息样式的方式.它们为典型的用户操作提供了上下文信息反馈. 您可以为警告框添加一个 ...
- 学习笔记:CentOS7学习之二十五:shell中色彩处理和awk使用技巧
目录 学习笔记:CentOS7学习之二十五:shell中色彩处理和awk使用技巧 25.1 Shell中的色彩处理 25.2 awk基本应用 25.2.1 概念 25.2.2实例演示 25.3 awk ...
- 无废话ExtJs 入门教程十五[员工信息表Demo:AddUser]
无废话ExtJs 入门教程十五[员工信息表Demo:AddUser] extjs技术交流,欢迎加群(201926085) 前面我们共介绍过10种表单组件,这些组件是我们在开发过程中最经常用到的,所以一 ...
- VMware vSphere 服务器虚拟化之二十五 桌面虚拟化之终端服务池
VMware vSphere 服务器虚拟化之二十五 桌面虚拟化之终端服务池 终端服务池是指由一台或多台微软终端服务器提供服务的桌面源组成的池.终端服务器桌面源可交付多个桌面.它具有以下特征: 1.终端 ...
- WCF技术剖析之二十五: 元数据(Metadata)架构体系全景展现[元数据描述篇]
原文:WCF技术剖析之二十五: 元数据(Metadata)架构体系全景展现[元数据描述篇] 在[WS标准篇]中我花了很大的篇幅介绍了WS-MEX以及与它相关的WS规范:WS-Policy.WS-Tra ...
- Bootstrap入门(二十五)JS插件2:过渡效果
Bootstrap入门(二十五)JS插件2:过渡效果 对于简单的过渡效果,只需将 transition.js 和其它 JS 文件一起引入即可.如果你使用的是编译(或压缩)版的bootstrap.js ...
随机推荐
- numpy基础一
常用,常忘 1.随机矩阵 np.random.rand(4,3) array([[ 0.06679473, 0.71073515, 0.5694172 ], [ 0.95018143, 0.60161 ...
- Integer int auto-boxing auto-unboxing ==
Auto-boxing 自动装箱 Auto-unboxing 自动拆箱 == 相等 1.new出来的对象,除非遇到了拆箱的情况,肯定不相等. 因为new对象之前需要在JVM堆中提供空间,所以new出来 ...
- Fltiss项目的架构、包名的定义和类的划分
这是项目的一览 首先Web根目录. 除了WEB-INF以外,还有css,img,js,lib目录,这四者都是静态资源. 由于客户端无法访问WEB-INF下的内容,所以将它们放置在了Web根目录下. 而 ...
- [linux]sudo 出现unable to resolve host 解决方法
Ubuntu环境, 假设这台机器名字(hostname)叫abc, 每次执行sudo 就出现这个警告讯息:sudo: unable to resolve host abc虽然sudo 还是可以正常执行 ...
- CTF辅助脚本
首先推荐这篇文章,网上有多次转载,这是我见过日期比较早的 CTF中那些脑洞大开的编码和加密 凯撒密码 flag='flag{abcdef}' c='' n=20 for i in flag: if ' ...
- 安装Rabbitmq脚本
安装RabbitMQ时需要先安装erlang插件 [root@ZHONG-LONG javascripts]# vim -erlang.sh #!/bin/sh ######安装erl插件 PRO=/ ...
- Ubuntu 18.04系统下arm-linux-gcc交叉编译器安装
Ubuntu 18.04系统: arm-linux-gcc 4.4.3版本. 安装arm-linux-gcc将压缩包arm-linux-gcc.tar.gz解压到arm-linux-gcc文件夹tar ...
- python定义接口继承类invalid syntax解决办法
class s_all(metaclass=abc.ABCMeta): #python2.7用此方法定义接口继承 # __metaclass__ = abc.ABCMeta @abc.abstract ...
- 阶段5 3.微服务项目【学成在线】_day03 CMS页面管理开发_12-删除页面-服务端-接口开发
删除页面 api里面定义接口 返回类型是ReponseResult @ApiOperation("删除页面") public ResponseResult delete(Strin ...
- 阶段5 3.微服务项目【学成在线】_day03 CMS页面管理开发_02-自定义查询页面-服务端-接口开发
在Service中实现自定义查询 StringUtils.isNotEmpty()是这个包下的org.apache.commons.lang3.StringUtils; 再设置其他的条件 定义Exam ...