首先在mysql中确立表:
#表一:地址国家表 CREATE TABLE address(aid INT AUTO_INCREMENT PRIMARY KEY,aname VARCHAR(20)); INSERT INTO address VALUES(NULL,"魏国"); INSERT INTO address VALUES(NULL,"蜀国"); INSERT INTO address VALUES(NULL,"吴国"); #表二:出场人物表 CREATE TABLE person( pid INT AUTO_INCREMENT PRIMARY KEY, pname VARCHAR(20), paid INT, CONSTRAINT pafk FOREIGN KEY person(paid) REFERENCES address(aid) ON UPDATE CASCADE ON DELETE CASCADE ); INSERT INTO person VALUES(1,"曹操",1); INSERT INTO person VALUES(2,"荀彧",1); INSERT INTO person VALUES(3,"张辽",1); INSERT INTO person VALUES(4,"刘备",2); INSERT INTO person VALUES(5,"关羽",2); INSERT INTO person VALUES(6,"张飞",2); INSERT INTO person VALUES(7,"诸葛亮",2); INSERT INTO person VALUES(8,"孙权",3); INSERT INTO person VALUES(9,"周瑜",3); INSERT INTO person VALUES(10,"陆逊",3); INSERT INTO person VALUES(11,"公孙瓒",NULL); #表三:交通工具表 CREATE TABLE tool(tid INT AUTO_INCREMENT PRIMARY KEY,tname VARCHAR(20)); INSERT INTO tool VALUES(1,"马"); INSERT INTO tool VALUES(2,"船"); #表四:地址国家——交通工具 多对多关系表 CREATE TABLE aandt( a_aid INT, a_tid INT, PRIMARY KEY(a_aid,a_tid),#联合主键,是指多个字段组成一个组合,该组合在数据表中唯一 CONSTRAINT FOREIGN KEY aandt(a_aid) REFERENCES address(aid) ON UPDATE CASCADE ON DELETE CASCADE, CONSTRAINT FOREIGN KEY aandt(a_tid) REFERENCES tool(tid) ON UPDATE CASCADE ON DELETE CASCADE ); INSERT INTO aandt VALUES(1,1); INSERT INTO aandt VALUES(2,1); INSERT INTO aandt VALUES(2,2); INSERT INTO aandt VALUES(3,2);
查询a表的所有信息,如果a表的信息有对应的b表的信息,则查询b表的信息,如果没有,则不查询。
一、连接查询:
连接查询使用时,使用偏向于a表所在方向的外连接,可获得a表所有信息,和对应的b表信息。该方式为饿汉式,内存占用较大,但对数据库访问次数较少而导致消耗时间少。
1、多对一:
2、一对多:
3、多对多:
二、嵌套查询:
嵌套查询使用时,先查询a表的信息,然后依赖a和b表的外键约束,利用in(),再次查询b表对应到a表上的信息。该方式可以改为饿汉式,内存使用较小,但需要多次访问数据库而导致消耗时间多。
1、多对一:
PersonDao接口内写入:
//查询所有人,以及其对应的地址 List
findPersonFromAddress();
对应映射配置中:
继续编写指向AddressDao接口中的findAddressById:
//按照id查询Address List findAddressById(Integer id);
回到AddressDao配置文件:
List findAddressWithPerson();
其对应映射配置中:
针对指出的PersonDao接口的findPersonById:
List
findPersonById(Integer id);
其对应的映射配置中:
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/176682.html原文链接:https://javaforall.net
