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;
}
}
最后一点:写完之后一定要将映射文件引入到核心配置文件中。