网页资讯视频图片知道文库贴吧地图采购
进入贴吧全吧搜索

 
 
 
日一二三四五六
       
       
       
       
       
       

签到排名:今日本吧第个签到,

本吧因你更精彩,明天继续来努力!

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
08月16日漏签0天
广东信息科技职业...吧 关注:1,716贴子:17,672
  • 看贴

  • 图片

  • 吧主推荐

  • 游戏

  • 0回复贴,共1页
<<返回广东信息科...吧
>0< 加载中...

JAVA笔记——JDBC多表查询

  • 只看楼主
  • 收藏

  • 回复
  • 可爱的林顺扬
  • 初涉江湖
    1
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
多表查询分别有三种表的关系:一对多 VS 多对一 VS多对多
具体是选择一对多、多对一还是多对多,在查询显示的时候,怎么显示,主要看我们的实际需求,显示一方的时候,是否需要显示另一方;
比如员工和部门的例子,部门表和员工表,就不应该选择双向绑定关系;因为在展示部门的时候,不需要将其下面的员工全部显示出来的;还有一点,就是多的一方数据很多,我们需要采用分页的技术进行显示;一对多,尽量避免,除非非要使用(比如订单)。使用的时候要注意数据量问题;
级联
·如果没设置级联,则需要先将依赖表的外键列置空。才能删除被依赖表;
·设置了级联(当删除被依赖表的记录时候,会自动将依赖表的外键列置空)
setnull :当外键依赖被删除的时候,会自动将外键列置空;
cascard: 当外键依赖被删除的时候,外键所在记录也会被删除;
多表增删改
·一对多:不需要多表查询;显示与不显示多的一方,只是sql条数的问题;插入的时候,可以在少的一方的dao层插入,也可以在多方dao层导入。
·多对多:如果需要显示多方的数据,则需要多表查询;插入的时候,一般写在少的一方的dao层里面,更新关系表,也写在这,减少代码量。
·查询的时候,如果不要求显示多的一方,则直接单表查询出少的一方。
·如果明确需要一并显示多的一方,则继续查询,查询的逻辑,就写在查询之前类的dao里面。
比如:老师与学生;在查询老师的时候,如果需要显示老师对应的学生,则继续在老师的Dao里面继续写逻辑。
举例:多对多表设计语句(学生老师)
// 学生表
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 foreignkey(teacher_id) references teacher(id) on delete cascade,
constraint student_id_FK foreignkey(student_id) references student(id) on delete cascade
);
如图:


登录百度账号

扫二维码下载贴吧客户端

下载贴吧APP
看高清直播、视频!
  • 贴吧页面意见反馈
  • 违规贴吧举报反馈通道
  • 贴吧违规信息处理公示
  • 0回复贴,共1页
<<返回广东信息科...吧
分享到:
©2025 Baidu贴吧协议|隐私政策|吧主制度|意见反馈|网络谣言警示