`

hibernate

阅读更多

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 jar包:hibernate-commons-annotations-4.0.1.Final.jar等

    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入门到精通" Hibernate 是一个基于Java的ORM(Object-Relational Mapping,对象关系映射)框架,它提供了一种简洁高效的方式来访问和操作关系数据库。下面是 Hibernate 的主要知识点: Hibernate 简介 ...

    hibernate jar包程序文件

    hibernate-commons-annotations-4.0.1.Final.jar hibernate-core-4.1.12.Final.jar hibernate-ehcache-4.1.12.Final.jar hibernate-entitymanager-4.1.12.Final.jar hibernate-jpa-2.0-api-1.0.1.Final.jar ...

    最新版本的Struts2+Spring4+Hibernate4框架整合

    项目原型:Struts2.3.16 + Spring4.1.1 + Hibernate4.3.6 二、 项目目的: 整合使用最新版本的三大框架(即Struts2、Spring4和Hibernate4),搭建项目架构原型。 项目架构原型:Struts2.3.16 + Spring4.1.1 + ...

    hibernate学习资料大全

    【hibernate学习资料大全】 Hibernate 是一个开源的对象关系映射(ORM)框架,它极大地简化了Java应用程序对数据库的操作。这个压缩包包含了丰富的Hibernate学习资源,旨在帮助开发者深入理解和熟练掌握这一强大的...

    Hibernate-extensions 完整安装包

    《Hibernate-Extensions全面指南》 Hibernate,作为Java领域中的一款著名对象关系映射(ORM)框架,极大地简化了数据库操作。然而,为了满足更复杂的业务需求,Hibernate还提供了丰富的扩展功能,这就是我们今天要...

    hibernate-release-4.1.4

    【描述】中的"hibernate的jar包"指的是Hibernate框架的运行库文件,这些JAR文件包含了Hibernate的所有核心API、实现和依赖库,如Hibernate Commons Annotations、Hibernate EntityManager、Hibernate Core等。...

    hibernate基础jar包

    Hibernate是一个开源的对象关系映射(ORM)框架,它允许Java开发者使用面向对象的方式来操作数据库,极大地简化了数据访问层的编程工作。这个压缩包包含了Hibernate的基础jar包,这些jar文件是开发Hibernate应用所...

    HibernateTools-3.2.4

    HibernateTools是Java开发人员在使用Hibernate ORM框架时的有力辅助工具集,主要目的是为了提高开发效率,简化数据库操作。在HibernateTools 3.2.4版本中,它包含了一系列的特性与插件,以支持更便捷地进行对象关系...

    hibernate3全部jar包:hibernate3.jar.zip 下载

    Hibernate3 是一个强大的Java持久化框架,它允许开发者将数据库操作与业务逻辑解耦,使得应用程序的开发更为简便。这个“hibernate3全部jar包:hibernate3.jar.zip”包含了所有必要的库文件,方便用户一次性下载并...

    Hibernate3的依赖包

    Hibernate3是一个广泛使用的Java对象关系映射(ORM)框架,它允许开发者用面向对象的方式处理数据库操作,极大地简化了Java应用程序与数据库之间的交互。在这个"Hibernate3的依赖包"中,包含了运行Hibernate3应用...

    hibernate和MySQL的jar

    标题中的“hibernate和MySQL的jar”指的是Hibernate ORM框架与MySQL数据库之间的连接库。Hibernate是一种流行的Java对象关系映射(ORM)工具,它允许开发者使用面向对象的编程方式来操作数据库,而无需直接编写SQL...

    kingbaseV8 hibernate jdbc 驱动

    在Java开发环境中,与KingbaseV8数据库进行交互通常会用到Hibernate框架和JDBC驱动。 Hibernate是一个优秀的对象关系映射(ORM)框架,它简化了Java应用程序对数据库的操作,通过将Java对象与数据库表进行映射,...

    Hibernate 中文api 等学习资料

    标题"Hibernate 中文api 等学习资料"暗示了这是一组针对Hibernate ORM框架的中文学习资源,包括API文档和其他指南,旨在帮助用户更好地理解和使用Hibernate。 描述中的"hibernate orm框架api中文文档,学习资料,...

    hibernate.5.1.0.jar全部

    包含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入门jar包

    Hibernate是一款强大的Java持久化框架,它简化了数据库与Java对象之间的交互,使开发者可以更加专注于业务逻辑而不是数据访问层的实现。本压缩包提供的是Hibernate入门所需的jar包,包括了Hibernate的核心库以及与之...

    hibernate4.3完整jar包

    Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端...

    hibernate3必要jar包

    Hibernate3 是一个非常重要的Java持久化框架,它允许开发者将对象模型与数据库关系模型进行映射,从而简化了数据存取的过程。这个压缩包“hibernate3必要jar包”显然是针对Hibernate3版本的,已经去除了冗余的库文件...

    hibernate_3.2官方开发包

    Hibernate 是一个著名的开源对象关系映射(ORM)框架,它为Java开发者提供了便捷的数据持久化方式,使得在Java应用程序中操作数据库变得更加简单。这个“hibernate_3.2官方开发包”包含了所有你需要开发基于...

    hibernate4.3.11所需jar包

    Hibernate是一款强大的Java持久化框架,它为Java开发者提供了一种对象关系映射工具,使得开发者可以使用面向对象的方式来操作数据库,极大地简化了数据库操作。在Java应用中,尤其是在企业级应用开发中,Hibernate是...

Global site tag (gtag.js) - Google Analytics