Hibernate概述和增删改查入门

一、hiberante框架概述

(1).Hibernate是一种轻量级的javaEE持久层解决方案,是一种关系型数据库的ORM映射框架,是完全的对数据库SQL进行封装,使用java对象操作,生成相应的SQL,完成对底层数据的操作.

(2).使用Hibernate的好处

1.简化编码操作

2.应用其内部的优化机制(一级,二级缓存,抓取策略等),来提高数据的操作性能

3.可使用java对象操作数据库,能对底层数据操作进行完全的封装

 

二、Hibernate入门开发

1.搭建Hibernate环境,导入相应的jar包

可从http://sourceforge.net/projects/hibernate/files 下载开发包

所需jar包如下:

Hibernate概述和增删改查入门

一些包的描述:

*hibernate3.jar—— 核心jar包

*hibernate-jpa-2.0-api-1.0.1.Final.jar——hibernate注解、web项目中依赖 包

*slf4j,slf4j-log4j12-1.7.2.jar——hibernate框架使用默认日志技术,需要与log4j整合实现

 

2.建立相依的实体类,以及相应的hbm(映射文件)

A.创建实体类Person.java,包含的属性为id,name,city.其对应的映射文件为(Person.hbm.xml)

B.主要配置如下

 

<hibernate-mapping>
		<!-- 
		     name 完整类名,table 表名,catalog 数据库名
		 -->
		<class name="com.w2cboy.model.Person" table="person" catalog="ceshidb">
			<!-- 主键生成策略配置 -->
			<!-- 
			 name Perosn类中生成注解 属性名
			 column 表中列名
			 type 数据类型  (Java数据类型、Hibernate数据类型 、 SQL数据类型 )
			 -->
			<id name="id" column="id" type="int">
			     <!-- 使用本地策略 -->
			     <generator class="native"></generator>
			</id>
			<!-- 配置其它属性 -->
			<property name="name" column="name" type="java.lang.String"></property>
			<!-- SQL类型 必须编写 column 元素-->
			<property name="city" column="city" type="string"></property>
		</class>
</hibernate-mapping>



 

3.创建并配置hibernate核心配置文件

在src目录下创建hibernate.cfg.xml文件,主要配置JDBC连接信息

其配置信息如下

 

             <hibernate-configuration>
		<!-- Hibernate中数据库连接 通过 session对象进行管理  -->
		<session-factory>
			<!-- 连接数据库,必须配置 JDBC 四个基本连接参数 -->
			<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
			<property name="hibernate.connection.url">jdbc:mysql:///ceshidb</property>
			<property name="hibernate.connection.username">root</property>
			<property name="hibernate.connection.password">123</property>
			
			<!-- 配置数据库方言 不同 数据库 SQL 不完全一样-->
			<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
	
			<!-- 在控制台打印生成的SQL语句 -->
			<property name="hibernate.show_sql">true</property>
			<!-- 对控制台输出SQL语句进行格式化,为了方便阅读 -->
			<property name="hibernate.format_sql">true</property>
			<!-- 可以自动根据类生成DDL 建表语言,完成自动建表 -->
			<property name="hibernate.hbm2ddl.auto">update</property>
			
			<!-- 在核心配置文件中 加载 hbm 映射文件 -->
			<mapping resource="com/w2cboy/model/Person.hbm.xml"/>
		</session-factory>
           </hibernate-configuration>	
	



 

4.编写测试用例(实现CRUD操作)

1.session工具类:

 

 //实例化配置对象,加载配置文件 hibernate.cfg.xml
	Configuration configuration = new Configuration().configure();
	//创建会话连接工厂
	SessionFactory sessionFactory = configuration.buildSessionFactory();
	//创建会话	
	Session session = sessionFactory.openSession();
	//开启事务
	Transaction transaction = session.beginTransaction();
	//提交事务,释放资源		
	transaction.commit();
	session.close();
	sessionFactory.close();


2.CRUD操作

 

 

2) 根据id 查询 通过 Session类 提供 get/load 方法 
	     int id = 1;
	     Person person= (Person ) session.get(person .class, id);
3)修改update方法, 默认根据 id 修改 表其它所有字段  通过 Session类 提供 update
	     person person = new Person ();
	     person .setName("张三");
	     person .setCity("上海");
     session.update(person);

4)删除操作, 根据id 删除, 通过Session类提供 delete 
	     person person = new Person ();
	     person.setId(1);
	     session.delete(perosn);

5) 查询所有数据 
	通过Query 接口完成, Query接口 接收HQL 查询语句 
	Query提供子接口 SQLQuery , 接收SQL 查询语句 
	Hibernate框架内部提供,格式和SQL语句非常类似,区别SQL 面向数据表查询语句, HQL面向Java类和对象查询语句 

HQL查询
	   String hql = "from Person";//面向类和对象
	   Query query = session.createQuery(hql); //获得Query对象
           List<Person> persons= query.list();//执行查询

SQL 查询
	   String sql = "select * from person";
	   SQLQuery sqlQuery = session.createSQLQuery(sql);

所以总的来说,hiberante的配置文件,和映射文件是实现的关键。

 

 

 

你可能感兴趣的:(Hibernate,持久层框架)