SSH学习之Hibernate的配置文件

Hibernate的核心配置文件

Hibernate的配置文件主要分为两大类:核心配置文件和映射文件。
Hibernate的核心配置文件在单独使用Hibernate框架的时候(不整合其他框架),位置和名称一般是固定的(初学的时候不要较真这个问题)。通常将其放在src目录下,名称为hibernate.cfg.xml
在这里就给出了一些基本的核心配置文件的讲解。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
	<session-factory>
		<!-- 配置MySQL数据库信息 -->
		<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
		<property name="connection.url">jdbc:mysql://localhost:3306/数据库名</property>
		<property name="connection.username">用户名</property>
		<property name="connection.password">密码</property>
		
		<!-- 配置hibernate设置信息 -->
		<!-- Hibernate默认是使用jdbc方式来取的,如果使用连接池的方式的话,必须告诉Hibernate一声,让它不使用单纯的JDBC连接 -->
		<property name="hibernate.temp.use_jdbc_metadata_defaults">false</property>
		<!-- 控制台显示sql语句,默认为false -->
		<property name="hibernate.show_sql">true</property>
		<!-- hibernate帮助创建表
			update:如果没有表,会自动创建;如果有这个表就会自动更新
		 -->
		 <property name="hibernate.hbm2ddl.auto">update</property>
		<!--指定数据库的方言,指定MySQL-->
		<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
		<!-- 与本地线程绑定session
		通过sessionFactory调用getCurrentSession方法就能和本地线程ThreadLocal绑定
		但是使用的时候不需要手动关闭session,否则会报错
		-->
		<property name="hibernate.current_session_context_class">thread</property>
		
		<!-- 导入映射文件(实体和表之间的映射关系) -->
		<mapping resource="pojo/User.hbm.xml"/>
	</session-factory>
</hibernate-configuration>

如果有问题,可以将hibernate设置信息去掉。

Hibernate的映射文件

Hibernate为我们提供的最大的好处就是我们不需要直接写jdbc代码来操作数据库,而是通过操作对象实体来操作数据库。
映射文件的命名和位置也是有要求的:命名必须是:实体类名称.hbm.xml,比如User.hbm.xml,位置可以不确定,但是我们一般要求将实体类和映射文件放到同一个包下。
下面就以一个用户类为例:
映射文件:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC 
   "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
   "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
	<!-- 
		name属性:实体类的全路径,必选
		table属性:指明数据库中的表名,必选
		catalog属性:指明数据库的名称,可选
	 -->
	<class name="pojo.User" table="user" catalog="db_hibernate">
		<!-- 
			id标签:每一张表都必须要有唯一的标识符,必要
			name属性:标识符的名称,必选
			column属性:指定标识符对应表中的哪个字段,可选,默认为和标识符同名
			type属性:指定类型,可选,一般不写
		 -->
		<id name="id" column="id">
			<!-- 
				主键的生成策略
				native:根据不同的数据库而不同,MySQL的是整型并且自增长
			 -->
			<generator class="native"></generator>
		</id>
		<!-- 
			property标签:实体类和表字段的对应关系
			name属性:实体类的属性,必选
			column属性:表字段,可选,默认和实体类属性同名
			type属性:指定类型,可选,一般不写
		 -->
		<property name="username" column="username" />
		<property name="password" column="password" />
	</class>
</hibernate-mapping>
实体类:
package pojo;

public class User {

	private Integer id;
	private String username;
	private String password;
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getUsername() {
		return username;
	}
	public void setUsername(String username) {
		this.username = username;
	}
	public String getPassword() {
		return password;
	}
	public void setPassword(String password) {
		this.password = password;
	}
}
最后一点:写完之后一定要将映射文件引入到核心配置文件中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值