再论持久层
持久层设计
- 层:有清晰严格的逻辑编辑
- 持久层:专注于数据持久化的相对独立的领域
- MVC实现了架构上的解耦合,业务逻辑和数据存储逻辑直接的分离则是技术实现层面的解耦合,最终使得应用系统的逻辑结构和物理结构分离
- DAO模式:Data Accessor + Domain Object
- 资源管理:数据库连接池(空间换时间、资源重用、避免泄漏,代理模式和装潢模式的实际应用)、语句连接池
什么是ORM?
- 对象模型的优势:封装、继承、多态等
- 关系模型的优势:事务、完整性、索引等
映射设计方案
- 表入口
- 行入口(最适合事务脚本模式)
- 活动记录
- 数据映射器
ORM框架及产品
- 作用:减少乏味代码,提升工作效率;更加面向对象,更好的可维护性;更好的性能;独立于具体数据库;更好的可移植性
- 产品:Hibernate、MyBatis、JOOQ、TopLink、Spring Data等
Hibernate
概述
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。
必须的jar包
antlr-2.7.7.jar 语言转换,Hibernate利用它实现 HQL 到 SQL的转换
classmate-1.3.0.jar
dom4j-1.6.1.jar dom4j是一个Java的 XML API,类似于jdom,用来读写xml文件,这是必须的jar,Hibernate用它来读写配置文件,必须使用的jar
hibernate-commons-annotations-5.0.1.Final.jar 注解包
hibernate-core-5.2.8.Final.jar 核心包
hibernate-jpa-2.1-api-1.0.0.Final.jar
jandex-2.0.3.Final.jar
javassist-3.20.0-GA.jar 代码生成工具, Hibernate用它在运行时扩展 Java类和实现
jboss-logging-3.3.0.Final.jar 日志包
jboss-transaction-api_1.2_spec-1.0.1.Final.jar 事务包
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>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/hib?useUnicode=true&characterEncoding=utf8</property>
<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property>
<property name="show_sql">true</property>
<property name="format_sql">true</property>
<property name="current_session_context_class">thread</property>
<property name="hbm2ddl.auto">update</property>
<!-- <mapping resource="com/kygo/entity/User.hbm.xml"/> -->
<mapping class="com.kygo.entity.User"/>
</session-factory>
</hibernate-configuration>
如果使用xml映射对象需要在配置.xml里面写
<mapping resource="com/kygo/entity/User.hbm.xml"/>
注解要写
<mapping class="com.kygo.entity.User"/>
例子
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 package="com.kygo.entity">
<class name="User" table="tb_user">
<id name="username" length="20"/>
<property name="password" column="userpass" length="20" not-null="true"/>
<property name="email" length="50"/>
</class>
</hibernate-mapping>
注解
@Entity
@Table(name="tb_user")
public class User {
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
private Integer id;
@Column(unique=true, nullable=false, length=20)
private String username;
@Column(name="userpass", nullable=false, length=20)
private String password;
@Column(length=50)
private String email;
}
测试
User user = new User();
user.setUsername("kygo");
user.setPassword("123456");
user.setEmail("kygo@qq.com");
Configuration config = new Configuration().configure();
SessionFactory factory = config.buildSessionFactory();
Session session = factory.openSession();
Transaction tx = session.beginTransaction();
session.save(user);
// User user = session.get(User.class, 1);
// System.out.println(user.getUsername());
// System.out.println(user.getPassword());
// System.out.println(user.getEmail());
tx.commit();
factory.close();