hibernate 入门笔记

hibernate 框架体系结构


2,hibernate入门

2.1,ORM框架

Object:对象,java对象,此处特指JavaBean

Relational:关系,二维表,数据库中的表。

Mapping :映射|映射元数据,对象中属性,与表的字段,存在对应关系。

      

ORM 对象和表的映射,就是通过将Java对象映射到数据库表,通过操作Java对象,就可以完成对数据表的操作

 

Hibernate是一个数据持久化层的ORM框架,Hibernate提供了对关系型数据库增删改成操作,大大简化了数据访问层繁琐的重复性代码


2.2  主流的ORM框架

  1. Hibernate最流行ORM框架,通过对象-关系映射配置,可以完全脱离底层SQL
  2. MyBatis  是apache的一个开源项目 iBatis,支持普通 SQL查询,存储过程和高级映射的优秀持久层框架
  3. 轻量级的dao层组件(不算框架):Apache DBUtils 、Spring JDBCTemplate

3      入门案例【掌握】

3.1  Hibernatetool4.1.1插件安装








配置关联的dtd文件(安装插件的情况下这个步骤可以跳过)

3.2  编写流程

  1. 创建数据库和表
  2. 导入jar包
  3.  创建一个持久化类,编写映射文件 hibernate mapping(*.hbm.xml)
  4. 编写核心配置文件(hibernate.cfg.xml)--> 配置获得链接等参数
  5. 使用api测试


3.2.1  数据库和表

create database contacts;
use contact;
create table t_user(
  id int auto_increment primary key,
  name varchar(50),
  pwd varchar(30)
);

3.2.2  导入jar包


3.2.3  编写JavaBean + 映射文件


注意:上面两个文件需要在同包下,映射文件为 : 类名.hbm.xml

关于*.hbm.xml的书写规范可以直接在hibernate-release-4.1.1.Final文件夹中搜索*.hbm.xml

public class User {
	private Integer uid;
	private String username;
	private String password;
public Integer getUid() {
		return uid;
	}
	public void setUid(Integer uid) {
		this.uid = uid;
	}
	public String getUsername() {
		return username;
	}
	public void setUsername(String username) {
		this.username = username;
	}
	public String getPassword() {
		return password;
	}
}

<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
	<class name="com.chinasoft.entity.User" table="t_user">
      	<!-- 主键  access=field  直接读取字段值,不会调用setter和getter方法-->
        <id name="uid" type="java.lang.Integer">
            <column name="id" />
            <!-- 固定值:主键生成策略,使用数据库本地的方式(mysql自增,oracle序列) -->
            <generator class="native" />
        </id>
        
        <!-- 普通属性 -->
        <property name="username" type="java.lang.String">
            <column name="name" />
        </property>
        <property name="password" type="java.lang.String">
            <column name="pwd" />
        </property>
</class>
</hibernate-mapping>

注意点:实体类需要满足以下条件

  1. 提供一个无参数public访问控制符的构造器
  2. 提供一个标识属性用于映射数据表主键字段
  3. 所有属性提供public访问控制符的set  get 方法(javaBean)
  4. 标识属性应尽量使用基本数据类型的包装类型(包装类型可以表示null,基本数据类型不可以)
  5. 不要用final修饰实体 (将无法生成代理对象进行优化)

关于类名.hbm.xml的打开方式


3.2.4   编写核心配置文件

  1. 位置:src目录下
  2. 名称:hibernate.cfg.xml
  3. 关于hibernate.cfg.xml的书写规范:在hibernate-release.4.1.1.Final中搜索

 

Ctrl+shift+t : 打开open Type窗口

<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
	<!-- SessionFactory,相当于之前学习连接池配置 -->
	<session-factory>
		<!-- 基本4项 -->
		<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
		<property name="hibernate.connection.url">jdbc:mysql:///contacts</property>
		<property name="hibernate.connection.username">root</property>
		<property name="hibernate.connection.password">root</property>
	     <!--数据库方言,会针对不同的数据库生成有差异的sql语句 -->
 <property name="hibernate.dialect"> org.hibernate.dialect.MySQL5Dialect</property>
<!—-是否顯示sql語句 -->
<property name="show_sql">true</property>
<!—格式化sql語句 -->
<property name="format_sql">true</property>
		<!-- 添加映射文件:注意是路径不是包名 -->
		<mapping resource="com/test/hibernate/User.hbm.xml"/>
	</session-factory>
</hibernate-configuration>

3.2.5  测试


@Test
	public void testInsert(){
		User user = new User();
		user.setUsername("伟哥哥");
		user.setPassword("1234");
		
		
		//1 加载配置文件(hibernate.cfg.xml)获得核心配置对象
		Configuration config = new Configuration().configure();
		
		//2 获得工厂 SessionFactory,相当于连接池
		//hibernate4.0 之前这样创建
		//SessionFactory factory = config.buildSessionFactory();
		
		ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry();
		SessionFactory factory = config.buildSessionFactory(serviceRegistry);
		
		//3获得会话session,相当于链接Connection
		Session session = factory.openSession();
		//4 开启事务
		Transaction transaction = session.beginTransaction();
		
		//操作
		session.save(user);
		
		//5 提交事务 | 回滚事务
		transaction.commit();
		//6 释放资源--关闭session
		session.close();
		//7 释放资源--关闭工厂factory
		factory.close();
	}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值