Hibernate配置⽂件hibernate.xml,dynamic-insert=“true“,dynamic-update=“true“,where,避免重复设置主外键约束关系

hibernate.xml

hibernate.xml 配置 Hibernate 的全局环境。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
 "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
 "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>

	 <session-factory>
		 <!-- 数据源配置 -->
		 <property name="connection.username">root</property>
		 <property name="connection.password">root</property>
		 <property
		name="connection.driver_class">com.mysql.cj.jdbc.Driver</property>
		 <property name="connection.url">jdbc:mysql://localhost:3306/test?
		useUnicode=true&amp;characterEncoding=UTF-8</property>
		 
		 <!-- C3P0 -->
		 <property name="hibernate.c3p0.acquire_increment">10</property>
		 <property name="hibernate.c3p0.idle_test_period">10000</property>
		 <property name="hibernate.c3p0.timeout">5000</property>
		 <property name="hibernate.c3p0.max_size">30</property>
		 <property name="hibernate.c3p0.min_size">5</property>
		 <property name="hibernate.c3p0.max_statements">10</property>
		 
		 <!-- 数据库⽅⾔ -->
		 <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
		 
		 <!-- 打印SQL -->
		 <property name="show_sql">true</property>
		 
		 <!-- 格式化SQL -->
		 <property name="format_sql">true</property>
		 
		 <!-- 是否⾃动⽣成数据库 -->
		 <property name="hibernate.hbm2ddl.auto"></property>
		 
		 <!-- 注册实体关系映射⽂件 -->
		 <mapping resource="com/southwind/entity/People.hbm.xml"></mapping>
		 <mapping resource="com/southwind/entity/Customer.hbm.xml"></mapping>
		 <mapping resource="com/southwind/entity/Orders.hbm.xml"></mapping>
		 <mapping resource="com/southwind/entity/Account.hbm.xml"></mapping>
		 <mapping resource="com/southwind/entity/Course.hbm.xml"></mapping>
	 </session-factory>
</hibernate-configuration>

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

实体关系映射⽂件

在这里插入图片描述

hibernate-mapping 属性与class属性

package:给 class 节点对应的实体类统⼀设置包名,此处设置包名,class 的 name 属性就可以省略包名。
在这里插入图片描述
在这里插入图片描述

dynamic-insert="true"演示

在这里插入图片描述
执行的sql语句如下:
在这里插入图片描述
下面加上dynamic-insert=“true” ,执行sql语句如下:
在这里插入图片描述

dynamic-update="true"演示

在这里插入图片描述
执行sql如下:
在这里插入图片描述
我们只是想更新money字段,但上面附带着更新了其他的属性了,下面加上dynamic-update=“true” :
在这里插入图片描述
在这里插入图片描述

where:查询时给 SQL 添加 where 条件

在这里插入图片描述
在这里插入图片描述
加上where 之后:
在这里插入图片描述

id属性

在这里插入图片描述
在这里插入图片描述

property 属性

在这里插入图片描述

实体关系映射⽂件属性

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

下面演示一下 重复设置主外键约束关系:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
通过上面两个图我们发现,我们已经往orders表里面插入了两行记录了,但Hibernate又执行了update的操作,因为 Customer 和 Orders 都在维护⼀对多关系,所以会重复设置主外键约束关系。
如何避免这种情况?

1、在 Java 代码中去掉⼀⽅维护关系代码

2、通过配置来解决。

在这里插入图片描述

cascade:⽤来设置级联操作

如果不加cascade="delete"直接删除customer会报错,有两种应对方式:
一是先删除关联的Order,然后再去删除customer:

在这里插入图片描述
第二种就是使用cascade="delete"完成级联删除了:
在这里插入图片描述

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值