1.why——应用程序采用面向对象的设计方式,数据持久化采用关系的设计方式,彼此之间没法对应。
2.what
2.1:本质——ORM
2.1.1:什么是ORM——对象-关系映射;实现对象到关系数据库中表的自动持久化。
2.1.2:组成——Object+Relation+Mapping
3.应用程序持久化的常用技术
3.1:sql/jdbc——最基本
3.2:hibernate——orm
3.3:iBATIS——
3.4:Apache ojb——
3.5:jdo——
3.6:entity bean——
4.hibernate接口
*延迟模式——根据需要产生数据。
4.1:Session——连接、增加、根据id的删、改、查
4.1.1:查询方法【load——get】——load会报对象未找到异常,get不会;load支持延迟加载,而get不支持。
4.2:Transaction——事务
4.3:Query——查询多条记录。
4.3.1:【list——iterator】——list不支持延迟,iterator支持延迟;list只有一条SQL语句,在query.list()时产生/iterator在查询全部id,再通过代理Po对象的get方法查询单条记录。
5.hibernate流程
5.1:书写hibernate配置文件——hibernate-cfg.xml
*用该文件中的mapping resource标签指定映射文件位置。
*
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration>
<session-factory>
<property name="connection.username">sa</property>
<property name="connection.url">jdbc:jtds:sqlserver://localhost:1433/test</property>
<property name="dialect">org.hibernate.dialect.SybaseDialect</property>
<!-- 设置方言,连接某个具体的数据库 -->
<property name="myeclipse.connection.profile">test67</property>
<property name="connection.password">sa</property>
<property name="connection.driver_class">net.sourceforge.jtds.jdbc.Driver</property>
<property name="show_sql">true</property>
<!-- 打印出hibernate中的SQL语句 -->
<property name="format_sql">true</property>
<mapping resource="com/lovo/po/UserPO.hbm.xml" />
<!-- 在配置文件中指明mapping文件的位置。 -->
</session-factory>
</hibernate-configuration>
5.2:创建Po对象——
*集合类型的属性需要申明为list、set
*需要标识属性,如id
package com.lovo.po;
public class UserPO {
private int id;
private String username;
private String password;
/**
* 无参数构造方法
*/
public UserPO() {
}
/**
* 带参数的构造方法
* @param id
* @param username
*/
public UserPO(int id, String username) {
this.id = id;
this.username = username;
}
public int getId() {
return id;
}
public void setId(int 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;
}
}
5.3:书写mapping文件——类名.hbm.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" >
<hibernate-mapping>
<class name="com.lovo.po.UserPO" table="t_user">
<!-- 关连Po类和表 -->
<id name="id" column="pk_id" type="int">
<!-- 属性从特殊的先开始写 -->
<generator class="increment"></generator>
<!-- 实现标识字段在hibernate中的自动增长 -->
</id>
<property name="username" column="f_name" type="string"></property>
<!-- 数据类型可以为Java的和hibernate的 -->
<property name="password" column="f_password" type="string"></property>
<!-- 实现类属性和表列的关连,并通过type指明字段在hibernate中的类型 -->
</class>
</hibernate-mapping>
UserDao。Java
package com.lovo.dao;
import java.util.Iterator;
import java.util.List;
import org.hibernate.Criteria;
import org.hibernate.Hibernate;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.criterion.DetachedCriteria;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Restrictions;
import com.lovo.db.HibernateSessionFactory;
import com.lovo.po.UserPO;
public class UserDAO {
public void addUser(UserPO user) {
Session session = HibernateSessionFactory.getSession();//获得连接
Transaction trans = session.beginTransaction();//创建事务
session.save(user);//添加记录
trans.commit();
session.close();
}
public void modUser(UserPO user) {
Session session = HibernateSessionFactory.getSession();
Transaction trans = session.beginTransaction();
session.update(user);//修改记录,需要根据标识属性来改
trans.commit();
session.close();
}
public void delUser(UserPO user) {
Session session = HibernateSessionFactory.getSession();
Transaction trans = session.beginTransaction();
session.delete(user);//删除记录,需要根据标识属性来删
trans.commit();
session.close();
}
public void getUser(int id) {查询方法一:通过Session接口,需要根据标识属性来查
Session session = HibernateSessionFactory.getSession();
// UserPO user = (UserPO)session.get(UserPO.class, id);
// System.out.println(user);
UserPO user = (UserPO) session.load(UserPO.class, id);//load会报异常,支持延迟;get不报错,不支持延迟
System.out.println(user);
session.close();
}
public void queryUser() {查询方法二:通过hql语句
String hql = "from UserPO";//hql——支持面向对象
Session session = HibernateSessionFactory.getSession();
Query query = session.createQuery(hql);//查询多条记录,并放入query容器中。
// List<UserPO> list = query.list();//只有一条SQL语句,并查询数据库
// for(UserPO userPO : list){
// System.out.println(userPO.getUsername());
// }
Iterator it = query.iterate();//查询多条记录。查询全表找出表中的ID。
while (it.hasNext()) {
UserPO user = (UserPO) it.next();
String username = user.getUsername();//通过代理模式根据id查询数据库
System.out.println(username);
}
session.close();
}
public void useQueryUpdate(UserPO user) {查询方法三:通过Query接口查询多条记录
String hql = "update UserPO set password = :password "
+ "where username = :username";
//
//
//
Session session = HibernateSessionFactory.getSession();
Transaction trans = session.beginTransaction();
Query query = session.createQuery(hql);
// query.setString(0, user.getPassword());hql语句按位绑定(?)
// query.setString(1, user.getUsername());
// query.setString("mima", user.getPassword());hql语句按名绑定(任意取)
// query.setString("xinming", user.getUsername());//注意 :username 没有空格
// query.setParameter(0, user.getPassword(),Hibernate.STRING);
// query.setParameter(1, user.getUsername());//以上2个方法一样,在需要更明确的数据类型时用第一个,其他时间可以用第二个
//hibernate.DATE;hibenate.TIMETAMPE
query.setProperties(user);按对象绑定;hql中参数绑定方式为:属性名
query.executeUpdate();
trans.commit();
session.close();
}
public void useSQLQuery() {
String sql = "select * from t_user";
Session session = HibernateSessionFactory.getSession();
Query query = session.createSQLQuery(sql);
List<Object[]> list = query.list();
for (Object[] userPO : list) {
System.out.println(userPO[0] + " " + userPO[1] + " "
+ userPO[2]);
}
session.close();
}
public void useCriteria(int page) {查询方法四:利用Criteria
Session session = HibernateSessionFactory.getSession();
Criteria criteria = session.createCriteria(UserPO.class);
//方法:restriction.and;
// criteria.add(Restrictions.sqlRestriction("pk_id = 3"));//为criteria添加查询条件;例如Restrictions.and、Restriction.or
criteria.addOrder(Order.desc("id"));
criteria.addOrder(Order.asc("username"));//以username降序排列
分页
criteria.setFirstResult(0 + 2 * page);//每页的第一条记录是总记录数的第几条
criteria.setMaxResults(2);//每页显示的记录数
List<UserPO> list = criteria.list();//查询数据库
for (UserPO userPO : list) {
System.out.println(userPO.getUsername());
}
session.close();
}
public void useDetachedCriteria(DetachedCriteria dc){查询方法五:利用DetachedCriteria
Session session = HibernateSessionFactory.getSession();
Criteria criteria = dc.getExecutableCriteria(session);//将离线的criteria容器对象转为在线对象。
List<UserPO> list = criteria.list();//从容器中读取数据
for (UserPO userPO : list) {
System.out.println(userPO.getUsername());
}
session.close();
}
}
调用类
public class TestService {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
UserPO user = new UserPO();
//user.setId(1);
user.setUsername("FRMM");
user.setPassword("WYAJWW");
UserDAO dao = new UserDAO();
dao.useSQLQuery();
}
}
分享到:
相关推荐
Hibernate 配置各种数据库 Hibernate 是一个基于 Java 的持久层框架,提供了一个抽象的数据访问层,能够与多种数据库进行集成。在 Hibernate 的配置文件中,我们可以配置不同的数据库连接,包括驱动程序、URL 等...
Hibernate.jar包,Hibernate可以应用在任何使用JDBC的场合,包含 hibernate-commons-annotations-4.0.1.Final.jar hibernate-core-4.1.12.Final.jar hibernate-ehcache-4.1.12.Final.jar hibernate-entitymanager-...
"Hibernate入门到精通" Hibernate 是一个基于Java的ORM(Object-Relational Mapping,对象关系映射)框架,它提供了一种简洁高效的方式来访问和操作关系数据库。下面是 Hibernate 的主要知识点: Hibernate 简介 ...
项目原型:Struts2.3.16 + Spring4.1.1 + Hibernate4.3.6 二、 项目目的: 整合使用最新版本的三大框架(即Struts2、Spring4和Hibernate4),搭建项目架构原型。 项目架构原型:Struts2.3.16 + Spring4.1.1 + ...
【hibernate学习资料大全】 Hibernate 是一个开源的对象关系映射(ORM)框架,它极大地简化了Java应用程序对数据库的操作。这个压缩包包含了丰富的Hibernate学习资源,旨在帮助开发者深入理解和熟练掌握这一强大的...
《Hibernate-Extensions全面指南》 Hibernate,作为Java领域中的一款著名对象关系映射(ORM)框架,极大地简化了数据库操作。然而,为了满足更复杂的业务需求,Hibernate还提供了丰富的扩展功能,这就是我们今天要...
【描述】中的"hibernate的jar包"指的是Hibernate框架的运行库文件,这些JAR文件包含了Hibernate的所有核心API、实现和依赖库,如Hibernate Commons Annotations、Hibernate EntityManager、Hibernate Core等。...
Hibernate是一个开源的对象关系映射(ORM)框架,它允许Java开发者使用面向对象的方式来操作数据库,极大地简化了数据访问层的编程工作。这个压缩包包含了Hibernate的基础jar包,这些jar文件是开发Hibernate应用所...
HibernateTools是Java开发人员在使用Hibernate ORM框架时的有力辅助工具集,主要目的是为了提高开发效率,简化数据库操作。在HibernateTools 3.2.4版本中,它包含了一系列的特性与插件,以支持更便捷地进行对象关系...
在Java开发环境中,与KingbaseV8数据库进行交互通常会用到Hibernate框架和JDBC驱动。 Hibernate是一个优秀的对象关系映射(ORM)框架,它简化了Java应用程序对数据库的操作,通过将Java对象与数据库表进行映射,...
Hibernate3 是一个强大的Java持久化框架,它允许开发者将数据库操作与业务逻辑解耦,使得应用程序的开发更为简便。这个“hibernate3全部jar包:hibernate3.jar.zip”包含了所有必要的库文件,方便用户一次性下载并...
Hibernate3是一个广泛使用的Java对象关系映射(ORM)框架,它允许开发者用面向对象的方式处理数据库操作,极大地简化了Java应用程序与数据库之间的交互。在这个"Hibernate3的依赖包"中,包含了运行Hibernate3应用...
标题中的“hibernate和MySQL的jar”指的是Hibernate ORM框架与MySQL数据库之间的连接库。Hibernate是一种流行的Java对象关系映射(ORM)工具,它允许开发者使用面向对象的编程方式来操作数据库,而无需直接编写SQL...
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端...
标题"Hibernate 中文api 等学习资料"暗示了这是一组针对Hibernate ORM框架的中文学习资源,包括API文档和其他指南,旨在帮助用户更好地理解和使用Hibernate。 描述中的"hibernate orm框架api中文文档,学习资料,...
包含hibernate所有所需jar包还有一些其他包日志包、jpa支持包等: 列如:hibernate-core-5.1.0.Final.jar hibernate-ehcache-5.1.0.Final.jar hibernate-entitymanager-5.1.0.Final.jar hibernate-envers-5.1.0....
Hibernate是一款强大的Java持久化框架,它简化了数据库与Java对象之间的交互,使开发者可以更加专注于业务逻辑而不是数据访问层的实现。本压缩包提供的是Hibernate入门所需的jar包,包括了Hibernate的核心库以及与之...
Hibernate3 是一个非常重要的Java持久化框架,它允许开发者将对象模型与数据库关系模型进行映射,从而简化了数据存取的过程。这个压缩包“hibernate3必要jar包”显然是针对Hibernate3版本的,已经去除了冗余的库文件...
Hibernate 是一个著名的开源对象关系映射(ORM)框架,它为Java开发者提供了便捷的数据持久化方式,使得在Java应用程序中操作数据库变得更加简单。这个“hibernate_3.2官方开发包”包含了所有你需要开发基于...
在Java开发领域,Hibernate是一个非常重要的对象关系映射(ORM)框架,它简化了数据库操作,使得开发者可以使用面向对象的方式来处理数据。当涉及到Hibernate项目时,为了使其正常运行,通常需要一系列的JAR(Java ...