Hibernate学习笔记(2)---hibernate核心文件

配置hibernate.cfg.xml

hibernate配置文件包含连接持久层与映射文件所需的基本信息。配置文件名默认为hibernate.cfg.xml.

hibernate.cfg.xml文件配置

<span style="font-size:18px;"><!-- 配置文件的DTD信息 -->
<!DOCTYPE hibernate-configuration PUBLIC
          "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- Generated by MyEclipse Hibernate Tools.                   -->
<!-- 配置文件的根元素 -->
<hibernate-configuration>

	<session-factory>
		<!-- 配置数据库方言 -->
		<property name="dialect">
			org.hibernate.dialect.MySQLDialect
		</property>
		<!-- 配置数据库连接URL -->
		<property name="connection.url">
			jdbc:mysql://localhost:3306/user
		</property>
		<!-- 配置数据库用户名 -->
		<property name="connection.username">root</property>
		<!-- 配置数据库密码 -->
		<property name="connection.password">123456</property>
		<!-- 配置数据库JDBC驱动 -->
		<property name="connection.driver_class">
			com.mysql.jdbc.Driver
		</property>

		<property name="myeclipse.connection.profile">driver</property>
		<!-- 底部输出sql语句 -->
		<property name="show_sql">true</property>
		<!-- 底部输出sql语句格式化 -->
		<property name="hibernate.format_sql">true</property>

		<!-- 把配置文件导入核心文件 ,后面会写到 -->
		<mapping resource="cn/dto/User.hbm.xml" />

	</session-factory>

</hibernate-configuration></span>

  

hibernate映射文件配置(*.hbm.xml)

持久化类的对象与关系数据库之间的映射关系通过.xml文件配置,通常命名为持久化类名.hbm.xml,这个文件一般放在持久化类对象相同路径下


*.hbm.xml文件配置(一般有多少持久化类对象就需要配置多少配置文件)

以User.hb,.xml文件配置举例

User.hbm.xml

<span style="font-size:18px;"><!-- 配置文件的DTD信息 -->
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
    Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<!-- 配置类和表的对应
	class标签
	name属性 :实体类的全路径(也就是User.java的路径)
	table属性:数据库表的名字
 -->
    <class name="cn.dto.User" table="t_user" catalog="user">
    <!-- 配置实体类id与表id对应
    		hibernate要求实体类有一个属性问一值
    		id标签
    		name属性 实体类里面id的属性名
    		column name:表字段名称
     -->
        <id name="uid" type="java.lang.Integer">
        <!-- column name:表字段名称
        	generator 设置数据表id的增长策略
        	native 主键自增长
         -->
            <column name="uid" />
            <generator class="identity" />
        </id>

        <property name="username" type="java.lang.String">
            <column name="username" length="32" />
        </property>
        <property name="password" type="java.lang.String">
            <column name="password" length="32" />
        </property>
        <property name="address" type="java.lang.String">
            <column name="address" length="32" />
        </property>
    </class>
</hibernate-mapping></span>

  

配置文件扩展

hibernate.cfg.xml配置C3P0连接池

<span style="font-size:18px;"><!-- 设置c3p0连接池的最大连接数 -->
		<property name="hibernate.c3p0.max_size">50</property>
		<!-- 设置c3p0连接池的最小连接数 -->
		<property name="hibernate.c3p0.min_size">1</property>
		<!-- 设置c3p0连接池中连接的超时时长,超出时抛出异常,单位为毫秒 -->
		<property name="hibernate.c3p0.timeout">1000</property>
		<!-- 设置c3p0缓存statements的数量 -->
		<property name="hibernate.c3p0.max_statements">60</property></span>

  

更多的c3p0连接池配置,请参考hibernate的etc子目录的properties文件

*.hbm.xml---集合的映射配置

set,map, list集合配置

<集合类映射元素>

<集合外键>

<j集合索引字段>

<集合元素/>

</集合类映射元素>

时间: 2024-10-03 22:51:47

Hibernate学习笔记(2)---hibernate核心文件的相关文章

Hibernate学习笔记(2)Hibernate问题

(1)数据库驱动问题 log4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment). log4j:WARN Please initialize the log4j system properly. Exception in thread "main" org.hibernate.HibernateException: JDBC Driver class not found: com.m

Hibernate学习笔记(一) — hibernate的配置文件简介与执行原理

一.初识Hibernate 1.JDBC的缺点: 1).编写代码的时候过于繁琐,try和catch比较多2).没有做数据缓存 3).不是面向对象编程 4).sql语句固定,可移植性差 JDBC的优点:效率比较高 2.Hibernate优点 1).完全面向对象编程 2).hibernate的缓存很牛的,一级缓存,二级缓存,查询缓存3).跨平台性强 4).使用场合多应用于企业内部的系统 Hibernate缺点 1).效率低 2).表中的数据如果在千万级别,则hibernate不适合 3).如果表与表

Hibernate学习笔记(六) — Hibernate的二级缓存

我们知道hibernate的一级缓存是将数据缓存到了session中从而减少与数据库的交互.那么二级缓存呢? 一.应用场合 比如,在12306购票时,需要选择出发地与目的地,如果每点一次都与数据库交互一次,这就很不合适,这些地点数据在相当长的一段时间内是不会发生变化的(山东省在相当长的时间内还叫山东省),所以应该缓存起来,没必要每次都与数据库交互,而且该类数据安全性也不是很高. 适合二级缓存的数据: 在现代软件开发中,确实存在一类数据没有什么私有性,为公开的数据,数据基本上不发生变化,该数据保密

Hibernate学习笔记(三) — Hibernate 的一级缓存意义

什么是缓存? 缓存说白了,就是应用程序向数据库要数据,然后把一些数据,临时的放在了内存的区域中,第二次再要数据的时候,直接从内存中拿即可. 缓存需要解决的事情: 1.能把数据放入缓存 2.能把数据从缓存中取出来 3.如果缓存中的数据发生变化,需要把数据同步到数据库中 4.把数据库中的数据同步到缓存中 5.hits命中率低的对象应该及时从缓存中移走 分布式缓存: 为什么会有分布式缓存? 应用程序运行在服务器上,并发访问时,服务器压力过大,分布式缓存就是来分担服务器压力的. 分布式缓存之间的数据是同

hibernate学习笔记之一 hibernate简介

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架 hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库. Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久

Hibernate学习笔记(九) — Hibernate的查询

Hibernate共提供以下三种检索方式 HQL检索方式: 1.通过 Session 的 createQuery() 方法创建一个 Query 对象, 它包括一个 HQL 查询语句. HQL 查询语句中可以包含命名参数 2.动态绑定参数 3.调用 Query 的 list() 方法执行查询语句. 该方法返回java.util.List 类型的集合, 在 List 集合中存放了符合查询条件的持久化对象. 4.Qurey 接口支持方法链编程风格, 它的 setXxx() 方法返回自身实例 Hiber

ShopNC学习笔记二:核心文件及常量介绍

ShopNC商城程序的框架文件主要由类文件和函数文件组成. 系统类库主要存放在framework下的libraries.cache.core和tpl目录中,librarites存放的是一些类库,cache下是存放多种缓存驱动类,core下存放的是核心基类和模型处理类,tpl只存放视图类Tpl. 1)      主要类文件及简要说明 libraries/email.php                 邮件发送类 libraries/ftp.php                    ftp处

Hibernate学习笔记(3)

两年前曾经学习过Hibernate,也通过博客将Hibernate的学习过程记录下来了,地址如下: Hibernate学习笔记(1) Hibernate学习笔记(2) 最近在复习Hibernate,在重新学习的过程中,有了一些新的体会和收获,现在将其总结成博客,供以后作为参考资料使用. 一.导入相应的jar包 目前Hibernate更新到了4.x版本,在官网下载后,找到lib文件加中的required文件夹,此外还需要额外导入log4j和数据库驱动包. 二.创建Hibernate配置文件 在sr

《Hibernate学习笔记八》:组件映射

<Hibernate学习笔记八>:组件映射 前面介绍了一对一的单向.双向外键关联,例如,学生证和学生是一个一对一的关系.这篇博文主要是介绍下组件映射,即一个是另一个的一部分,例如,学生证的信息也可以作为学生信息的一部分,即在数据库中只存在学生一个表,而不是有学生和学生证两个表,并且这两个表中有一个一对一的关联关系. 如下: 有人或许会说,那我们就将学生和学生证的信息写在一个类中,则就不需要组件映射了,确实可以这样,但是,根据类的设计原则,我们一般都会将其设计为两个类,然后将学生证的信息作为一个

Hibernate学习笔记:第一个程序的搭建

Hibernate学习笔记:第一个程序的搭建 前一段时间对Struts2这个框架有了一点点地了解,很高兴,自己开始学习Hibernate这个框架了.本篇博文将记录下第一个Hibernate程序的搭建过程.其实有时候个人觉得无论我们学习什么语言也好,还是学习什么框架也好,第一个HelloWorld程序真的相当重要,假如 我们在学习第一个HelloWorld程序都跑不出来,这完全影响着我们对新接触的东西的兴趣和动力,但是,往往第一个程序都会涉及到很多的配置,因此使得对于初学者要摸索一定的时间,对于我