Hibernate学习三 一对多和多对多 整合ing

一、Hibernate的基本查询

1.1 Query接口(HQL)

  • 具体的查询代码如下
 // 1.查询所有记录
	Query query = session.createQuery("from Customer");
    List<Customer> list = query.list();
    System.out.println(list); 
// 2.条件查询:
   	Query query = session.createQuery("from Customer where name = ?");
    query.setString(0, "李健");
    List<Customer> list = query.list();
    System.out.println(list);
// 3.条件查询:
 	Query query = session.createQuery("from Customer where name = :aaa and age = :bbb");
    query.setString("aaa", "李健");
    query.setInteger("bbb", 38);
    List<Customer> list = query.list();
    System.out.println(list);

1.2 Criteria接口(QBC)(做条件查询非常合适)

  • 具体的查询代码如下
// 1.查询所有记录
 	Criteria criteria = session.createCriteria(Customer.class);
    List<Customer> list = criteria.list();
    System.out.println(list);

// 2.条件查询
    Criteria criteria = session.createCriteria(Customer.class);
    criteria.add(Restrictions.eq("name", "李健"));
    List<Customer> list = criteria.list();
    System.out.println(list);

// 3.条件查询
    Criteria criteria = session.createCriteria(Customer.class);
    criteria.add(Restrictions.eq("name", "李健"));
    criteria.add(Restrictions.eq("age", 38));
    List<Customer> list = criteria.list();
    System.out.println(list);

一、Hibernate的关联 一对多映射(重点)

1.1 JavaWEB中一对多的设计及其建表原则

1.2 先导入SQL的建表语句

  • 创建今天的数据库:create database hibernate_day03;

1.3 编写客户和联系人的JavaBean程序(注意一对多的编写规则)

  • 客户的JavaBean如下
        public class Customer {
            private Long cust_id;
            private String cust_name;
            private Long cust_user_id;
            private Long cust_create_id;
            private String cust_source;
            private String cust_industry;
            private String cust_level;
            private String cust_linkman;
            private String cust_phone;
            private String cust_mobile;

            private Set<Linkman> linkmans = new HashSet<Linkman>();

        }
  • 联系人的JavaBean如下
        public class Linkman {
            private Long lkm_id;
            private String lkm_name;
            private String lkm_gender;
            private String lkm_phone;
            private String lkm_mobile;
            private String lkm_email;
            private String lkm_qq;
            private String lkm_position;
            private String lkm_memo;

            private Customer customer;

        }

1.4 编写客户和联系人的映射配置文件(注意一对多的配置编写)

  • 客户的映射配置文件如下
  <class name="domain.Customer" table="cst_customer">
            <id name="cust_id" column="cust_id">
                <generator class="native"/>
            </id>
            <property name="cust_name" column="cust_name"/>
            <property name="cust_user_id" column="cust_user_id"/>
            <property name="cust_create_id" column="cust_create_id"/>
            <property name="cust_source" column="cust_source"/>
            <property name="cust_industry" column="cust_industry"/>
            <property name="cust_level" column="cust_level"/>
            <property name="cust_linkman" column="cust_linkman"/>
            <property name="cust_phone" column="cust_phone"/>
            <property name="cust_mobile" column="cust_mobile"/>

            <set name="linkmans">
                <key column="lkm_cust_id"/>
                <one-to-many class="domain.Linkman"/>
            </set>
        </class>

  • 联系人的映射配置文件如下
 <class name="domain.Linkman" table="cst_linkman">
            <id name="lkm_id" column="lkm_id">
                <generator class="native"/>
            </id>
            <property name="lkm_name" column="lkm_name"/>
            <property name="lkm_gender" column="lkm_gender"/>
            <property name="lkm_phone" column="lkm_phone"/>
            <property name="lkm_mobile" column="lkm_mobile"/>
            <property name="lkm_email" column="lkm_email"/>
            <property name="lkm_qq" column="lkm_qq"/>
            <property name="lkm_position" column="lkm_position"/>
            <property name="lkm_memo" column="lkm_memo"/>

            <many-to-one name="customer" class="domain.Customer" column="lkm_cust_id"/>
        </class>

1.5 保存客户和联系人的数据

1.6 级联保存

1.6.1 测试:如果现在代码只插入其中的一方的数据

  • 如果只保存其中的一方的数据,那么程序会抛出异常。
  • 如果想完成只保存一方的数据,并且把相关联的数据都保存到数据库中,那么需要配置级联!!
  • 级联保存是方向性

1.6.2 级联保存效果

  • 级联保存:保存一方同时可以把关联的对象也保存到数据库中!!
  • 使用cascade=“save-update”

1.7 技术分析之级联删除
1.7.1 先来给大家在数据库中演示含有外键的删除客户功能,那么SQL语句是会报出错误的

  • 例如:delete from customers where cid = 1;

1.7.2 如果使用Hibernate框架直接删除客户的时候,测试发现是可以删除的

1.7.3 上述的删除是普通的删除,那么也可以使用级联删除,注意:级联删除也是有方向性的!!

  • <many-to-one cascade="delete" />

1.8 级联的取值(cascade的取值)和孤儿删除
1.8.1 需要大家掌握的取值如下

  • none – 不使用级联
  • save-update – 级联保存或更新
  • delete – 级联删除
  • delete-orphan – 孤儿删除.(注意:只能应用在一对多关系)
  • all – 除了delete-orphan的所有情况.(包含save-update delete)
  • all-delete-orphan – 包含了delete-orphan的所有情况.(包含save-update delete delete-orphan)

1.8.2 孤儿删除(孤子删除),只有在一对多的环境下才有孤儿删除

  • 在一对多的关系中,可以将一的一方认为是父方.将多的一方认为是子方.孤儿删除:在解除了父子关系的时候.将子方记录就直接删除。
  • <many-to-one cascade="delete-orphan" />

1.9 一方放弃外键的维护,为多对多做准备
1.9.2 先测试双方都维护外键的时候,会产生多余的SQL语句。

  • 想修改客户和联系人的关系,进行双向关联,双方都会维护外键,会产生多余的SQL语句。

  • 产生的原因:session的一级缓存中的快照机制,会让双方都更新数据库,产生了多余的SQL语句。

1.9.2 如果不想产生多余的SQL语句,那么需要一方来放弃外键的维护!

  • 在标签上配置一个inverse=”true”.true:放弃.false:不放弃.默认值是false
  • <inverse=“true”>

1.10 之cascade和inverse的区别

  • cascade用来级联操作(保存、修改和删除)
  • inverse用来维护外键的

二、Hibernate的关联关系映射之多对多映射

2.1 多对多的建表原则
2.1.1 JavaWEB的多对多

2.2 多对多JavaBean的编写
2.2.1编写用户和角色的JavaBean

  • 用户的JavaBean代码如下
  public class User {
            private Long user_id;
            private String user_code;
            private String user_name;
            private String user_password;
            private String user_state;

            private Set<Role> roles = new HashSet<Role>();
        }

  • 角色的JavaBean代码如下
        public class Role {
            private Long role_id;
            private String role_name;
            private String role_memo;

            private Set<User> users = new HashSet<User>();
        }

2.2.2 用户和角色的映射配置文件如下

  • 用户的映射配置文件如下
  <class name="domain.User" table="sys_user">
            <id name="user_id" column="user_id">
                <generator class="native"/>
            </id>
            <property name="user_code" column="user_code"/>
            <property name="user_name" column="user_name"/>
            <property name="user_password" column="user_password"/>
            <property name="user_state" column="user_state"/>

            <set name="roles" table="sys_user_role">
                <key column="user_id"/>
                <many-to-many class="domain.Role" column="role_id"/>
            </set>
        </class>
  • 角色的映射配置文件如下
 <class name="domain.Role" table="sys_role">
            <id name="role_id" column="role_id">
                <generator class="native"/>
            </id>
            <property name="role_name" column="role_name"/>
            <property name="role_memo" column="role_memo"/>

            <set name="users" table="sys_user_role">
                <key column="role_id"/>
                <many-to-many class="domain.User" column="user_id"/>
            </set>
        </class>

2.2.3多对多进行双向关联的时候:必须有一方去放弃外键维护权
2.3 多对多的级联保存
2.3.1 级联保存

  • <set cascade="save-update">

2.4 级联删除(在多对多中是很少使用的)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值