hibernate配置
来源:互联网 发布:扇形建筑算法 编辑:程序博客网 时间:2024/06/05 00:44
<?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>
<!-- Hibernate 连接数据库的基本信息 -->
<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql:///hibernate01</property>
<!-- Hibernate 的基本配置 -->
<!-- Hibernate 使用的数据库方言 -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 运行时是否打印SQL -->
<property name="show_sql">true</property>
<!-- 运行时是否格式化SQL -->
<property name="format_sql">true</property>
<!-- 生产数据表的策略 -->
<property name="hbm2ddl.auto">update</property>
<!-- 需要关联的Hibernate 映射文件 .hbm.xml-->
</hibernate-configuration>
//flush:使数据表中的记录和Session缓存中的对象状态保持一致,为了保持一致,则可能会发送对应的SQL 语句
1.在 Transaction 的commit()方法中:先调用session 的flush 方法,再提交事务
2. flush() 方法可能会发送SQL语句,但不会提交事务
注意: 在未提交事务或显示的调用 session.flush() 方法之前,也有可能会进行 flush() 操作
1). 执行 HQL 或 QBC 查询,会先进行flush() 操作,已得到数据表的最新的记录
2). 若记录的 ID 是由底层数据库使用自增的方式生成的,则在调用 save() 方法后,就会立即发送 INSERT 语句,因为save方法后,必须保证对象的ID是存在的。
//refresh():会强制发送 SELECT 语句,以使session 缓存中对象的状态和数据表中对应的记录保持一致
映射一对多:12n:///set属性
**映射 set 类型的属性,table:set 中的元素对应的记录放在哪个数据表中,该值需要和多对一的多的哪个表的名字一致
**inverse :指定由哪一方来维护关联关系,通常设置为true,以指定由多的一端来维护关联关系
**cascade="delete" 设定级联删除
**ordre-by :在查询时对集合中的元素进行排序, order-by 中使用的是表的字段名,不是持久化类的属性名
inverse:可以在 1 的一端的 set 节点设定inverse="true" 来使 1 这一端放弃维护关联关系
建议舍弟滚 set 的inverse=true 建议先插入 1 的一端,后插入多的一端
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- Hibernate 连接数据库的基本信息 -->
<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql:///hibernate01</property>
<!-- Hibernate 的基本配置 -->
<!-- Hibernate 使用的数据库方言 -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 运行时是否打印SQL -->
<property name="show_sql">true</property>
<!-- 运行时是否格式化SQL -->
<property name="format_sql">true</property>
<!-- 生产数据表的策略 -->
<property name="hbm2ddl.auto">update</property>
<!-- 需要关联的Hibernate 映射文件 .hbm.xml-->
<mapping resource="com/test/test.hbm.xml"/>
</hibernate-configuration>
//flush:使数据表中的记录和Session缓存中的对象状态保持一致,为了保持一致,则可能会发送对应的SQL 语句
1.在 Transaction 的commit()方法中:先调用session 的flush 方法,再提交事务
2. flush() 方法可能会发送SQL语句,但不会提交事务
注意: 在未提交事务或显示的调用 session.flush() 方法之前,也有可能会进行 flush() 操作
1). 执行 HQL 或 QBC 查询,会先进行flush() 操作,已得到数据表的最新的记录
2). 若记录的 ID 是由底层数据库使用自增的方式生成的,则在调用 save() 方法后,就会立即发送 INSERT 语句,因为save方法后,必须保证对象的ID是存在的。
//refresh():会强制发送 SELECT 语句,以使session 缓存中对象的状态和数据表中对应的记录保持一致
映射一对多:12n:///set属性
**映射 set 类型的属性,table:set 中的元素对应的记录放在哪个数据表中,该值需要和多对一的多的哪个表的名字一致
**inverse :指定由哪一方来维护关联关系,通常设置为true,以指定由多的一端来维护关联关系
**cascade="delete" 设定级联删除
**ordre-by :在查询时对集合中的元素进行排序, order-by 中使用的是表的字段名,不是持久化类的属性名
inverse:可以在 1 的一端的 set 节点设定inverse="true" 来使 1 这一端放弃维护关联关系
建议舍弟滚 set 的inverse=true 建议先插入 1 的一端,后插入多的一端
0 0
- hibernate-hibernate的配置
- 【Hibernate】2.Hibernate配置
- Hibernate 配置!
- Hibernate配置
- Hibernate配置
- Hibernate 配置
- Hibernate配置
- Hibernate配置
- Hibernate配置
- Hibernate配置
- hibernate 配置
- Hibernate 配置
- Hibernate 配置
- hibernate配置
- 配置HIbernate
- Hibernate 配置
- Hibernate配置
- Hibernate配置
- 深度剖析函数四个部分(返回值,参数,函数名,函数体)
- js中几种实用的跨域方法原理详解
- Kruskal算法
- python2.7_中文显示
- IDoc Inbound Process
- hibernate配置
- (hdu step 2.3.7)Last non-zero Digit in N!(阶乘最后一位非零位)
- TransactionScope的使用
- android 三种定位方式
- AJAX即时返回后台值
- Linux命令学习:awk
- docker 仓库创建和使用
- Java 内部类种类及使用解析
- Android线程小结