2024年3月20日发(作者:)

6.4 HQL的多表查询

对象之间总是有各种各样的关系,关联关系是类之间最常见的关系。多表查询是H

QL中的强大功能之一,包括内连接、左连接和右连接等。多表查询的设置及运行

都比较麻烦,在运行本节中的示例时,务必保证每一步都没有错误。

6.4.1 表之间的关联关系

在数据库joblog中用到了3个表:student(学生表)、course(课程表)和sc

(选课表)。这些表的详细信息见6.1.1节“示例中用到的默认数据库表和数

据”。在现实模型中,一个学生可以选择多门课程,一个课程可以被多个学生选

择,student和course是多对多的关联关系。为了便于演示HQL的多表查询,本

节中假设student和course之间是单向关联关系。

在多对多的关联关系中,一般来说有个中间表,这个表描述了多对多关系,这就是

选课表sc,sc每一行数据代表一个学生的选课和成绩。

各个表的主键、外键设置如下。

student表的主键是id字段。

course表的主键是id字段。

sc表的主键是id字段。

sc表中的Sno字段是student表id字段的外键。

sc表中的Cno字段是course表id字段的外键。

图6-8是3个表之间关系的直观表示。

图6-8 3个表之间的关系

在MySQL Query Browser中设置好上述关系。如果此处设置不正确,可能会影响多

表连接查询。其中sc表的建表信息如下(其中包含了外键关系)。

CREATE TABLE 'joblog'. 'sc' (

'id' int(10) unsigned NOT NULL auto_increment COMMENT 'id',

'Sno' int(10) unsigned NOT NULL default '0' COMMENT '学号',

'Cno' int(10) unsigned NOT NULL default '0' COMMENT '课程号',

'Grade' int(10) unsigned default NULL COMMENT '成绩',

PRIMARY KEY ('id'),

KEY 'FK_sc_1' ('Sno'),

KEY 'FK_sc_2' ('Cno'),

CONSTRAINT 'FK_sc_1' FOREIGN KEY ('Sno') REFERENCES 'student' ('id'), /* 外键信息 */

CONSTRAINT 'FK_sc_2' FOREIGN KEY ('Cno') REFERENCES 'course' ('id') /* 外键信息 */

) ENGINE=InnoDB DEFAULT CHARSET=gb2312;

6.4.2 表中的数据

这一节中用到了3个表的数据,student表和course表的数据如6.1节中图6-2

和6-4所示,但是sc表的内容变为图6-9所示的数据,其中Sno和Cno存储的分

别是student表和course表中对应的主键值。

图6-9 本节中所用的表sc中的内容

6.4.3 修改持久化类

Student对象和Course对象之间是多对多的关系。此处使用的是单向关联,仅仅

建立从Student到Course的单向关联。如图6-10所示,仅有Student到Course

的单向关联。