Hibernate的
官方网址:
http://hibernate.org/orm/
Hibernate的 核心组件:Configuration,SessionFactory,Session,Transaction,Query。
Configuration,负责读取主配置文件,并启动Hibernate,创建SessionFactory对象。
SessionFactory,负责初始化Hibernate,充当数据源的代理,创建Session;线程安全。
Session,负责执行持久化对象的操作,增(save)删(delete)改(update)查(get/load);非线程安全。
Transaction,负责事务相关的操作,由session.beginTransaction()生成,有commit/rollback方法。
Query,负责执行各种查询;由session.createQuery()生成,可用HQL语言,对持久化对象进行查询。
持久化对象( PO):普通的JavaBean,跟Session相关联,它有3种状态:临时态,持久态,托管态。
new()->临时态-save()->持久态-close()->托管态-update()->持久态-delete()->临时态。
Hibernate的 配置文件:Hibernate.cfg.xml,主配置;xxx.hbm.xml,对象与数据库表的映射配置。
Hibernate.cfg.xml,配置数据库连接参数,如数据库的驱动,URL,用户名和密码等;其内指定映射配置。
xxx.hbm.xml,用来把持久化对象(属性)与数据库表(字段),以及它们之间的关系(M:N),映射起来。
Hibernate的 核心组件:Configuration,SessionFactory,Session,Transaction,Query。
Configuration,负责读取主配置文件,并启动Hibernate,创建SessionFactory对象。
SessionFactory,负责初始化Hibernate,充当数据源的代理,创建Session;线程安全。
Session,负责执行持久化对象的操作,增(save)删(delete)改(update)查(get/load);非线程安全。
Transaction,负责事务相关的操作,由session.beginTransaction()生成,有commit/rollback方法。
Query,负责执行各种查询;由session.createQuery()生成,可用HQL语言,对持久化对象进行查询。
持久化对象( PO):普通的JavaBean,跟Session相关联,它有3种状态:临时态,持久态,托管态。
new()->临时态-save()->持久态-close()->托管态-update()->持久态-delete()->临时态。
Hibernate的 配置文件:Hibernate.cfg.xml,主配置;xxx.hbm.xml,对象与数据库表的映射配置。
Hibernate.cfg.xml,配置数据库连接参数,如数据库的驱动,URL,用户名和密码等;其内指定映射配置。
xxx.hbm.xml,用来把持久化对象(属性)与数据库表(字段),以及它们之间的关系(M:N),映射起来。
Hibernate.cfg.xml示例:
<?xml version="1.0" encoding="UTF-8"?>
<!-- DTD(Document Type Definition)文档类型定义;XML解析器,使用DTD文档来检查XML文件的合法性 -->
<!-- Hibernate版本不同,其DTD文档略有差异;切记,要使用与Hibernate版本相对应的DTD文档 -->
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<!-- Hibernate主配置文件的根元素 -->
<hibernate-configuration>
<!-- Hibernate初始化SessionFactory的参数 -->
<session-factory>
<span style="white-space:pre"> </span><!-- 指定Hibernate连接数据库时,所用的驱动 -->
<property name="hibernate.connection.driver_class">org.gjt.mm.mysql.Driver</property>
<!-- 设置数据库的连接地址(URL);localhost:本机,3306:端口号,push:数据库名 -->
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/push</property>
<!-- 指定数据库的用户名 -->
<property name="hibernate.connection.password">gjs@y1</property>
<!-- 指定数据库的密码 -->
<property name="hibernate.connection.username">root</property>
<!-- 指定数据库的方言;每种数据库,都有其对应的方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!-- 指定映射文件;映射文件可以有很多个 -->
<mapping resource="com/back/entity/User.hbm.xml" />
</session-factory>
</hibernate-configuration>
User.hbm.xml示例:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!-- Hibernate映射文件的根元素 -->
<hibernate-mapping>
<!-- 配置PO对象和数据库中表的对应关系,使用class元素 -->
<!-- name:PO对象;table:数据库表;catalog:数据库名 -->
<class name="com.back.entity.User" table="user" catalog="push">
<!-- 配置PO对象和数据库中表的id字段,即定义主键,使用id元素 -->
<!-- name:PO对象的属性;type:属性的类型 -->
<id name="id" type="java.lang.Integer">
<!-- column:数据表中的列 -->
<column name="id" />
<!-- generator:主键的生成方式 -->
<generator class="native" />
</id>
<!-- 配置PO对象和数据库中表的其他字段,使用property元素 -->
<property name="name" type="java.lang.String">
<column name="name" />
</property>
<property name="password" type="java.lang.String">
<column name="password" />
<span style="white-space:pre"> </span></property>
</class>
</hibernate-mapping>
测试代码:
package test;
import java.io.File;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import com.back.entity.User;
public class abcTest {
@SuppressWarnings("deprecation")
public static void main(String[] args) throws Exception {
File file = new File("src/hibernate.cfg.xml");
System.out.println("file path:" + file.getAbsolutePath());
Configuration cfg = new Configuration().configure(file);
SessionFactory sf = cfg.buildSessionFactory();
Session session = sf.openSession();
Transaction tx = session.beginTransaction();
User user = new User();
user.setName("test");
user.setPassword("password");
Integer id = (Integer) session.save(user);
System.out.println("save() id:" + id);
user = (User) session.get(User.class, id);
if (user != null) {
System.out.println("id:" + user.getId() + ",name:" + user.getName()
+ ",password:" + user.getPassword());
}
// session.delete();
String delStr = "delete from User where name=:name and password=?0";
Query query = session.createQuery(delStr);
query.setString("name", "test");
query.setParameter("0", "password");
int count = query.executeUpdate();
System.out.println("executeUpdate() count:" + count);
tx.commit();
session.close();
System.out.println("done.");
}
}