在Hibernate中使用HQL通过Join进行关联查询

本文介绍了如何在Hibernate中通过HQL进行关联查询,以Person和Car为例,展示了数据结构、hbm.xml配置和查询代码。重点在于利用'join'和'new map()'来获取并展示关联数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.youkuaiyun.com/jiangjunshow

               

先来个简单的:

1、数据结构:

create table one11_person(
 id varchar(32) not null,
 name varchar(20)
);
alter table one11_person
 add constraint one11_person_pk primary key(id);
create table one11_car(
 id varchar(32) not null,
 name varchar(20),
 personid varchar(32)
);
alter table one11_car
 add constraint one11_car_pk primary key(id);
alter table one11_car
 add constraint one11_car_fk foreign key(personid) references one11_person(id);

注意表之间的对应关系。

实体关系图如下:

图片

2:hbm.xml文件:

Person.hbm.xml文件:

<hibernate-mapping>
    <class name="com.one11.One11Person" table="one11_person" catalog="spring">
        <id name="id" type="java.lang.String">
            <column name="id" length="32" />
            <generator class="uuid" />
        </id>
        <property name="name" type="java.lang.String">
            <column name="name" length="20" />
        </property>
        <set name="one11Cars" cascade="all">
            <key>
                <column name="personid" length="32" />
            </key>
            <one-to-many class="com.one11.One11Car" />
        </set>
    </class>
</hibernate-mapping>

Car.bbm.xml文件:

<hibernate-mapping>
    <class name="com.one11.One11Car" table="one11_car" catalog="spring">
        <id name="id" type="java.lang.String">
            <column name="id" length="32" />
            <generator class="uuid" />
        </id>
        <many-to-one name="one11Person" class="com.one11.One11Person" fetch="select">
            <column name="personid" length="32" />
        </many-to-one>
        <property name="name" type="java.lang.String">
            <column name="name" length="20" />
        </property>
    </class>
</hibernate-mapping>

3:类文件略。

4:关联查询代码:

public void query(){
  Session s = HibernateUtil.getSessionFactory().getCurrentSession();
  s.beginTransaction();
  List list = s.createQuery("select new map(p.name as pname,c.name as cname) from One11Person as p join p.one11Cars as c").list();
  s.getTransaction().commit();
  System.err.println(list);
 }

粗体部分为查询语句。其中使用了new map()和join关键字。对于join之后的one11Cars属于p的一个属性。

注意上面的红体字部分。

           

分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.youkuaiyun.com/jiangjunshow

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值