hibernate4框架的增删查改(包含hql)数据等功能方法

简介: 版权声明:本文为博主原创文章,如需转载,请标明出处。 https://blog.csdn.net/alan_liuyue/article/details/53388869 本次...
版权声明:本文为博主原创文章,如需转载,请标明出处。 https://blog.csdn.net/alan_liuyue/article/details/53388869

本次程序测试的是hibernate4框架的增加、修改、删除、查询等方法,每种功能都集合了几种简单的方法来进行测试,程序猿可按需获取;

hibernate框架搭建之后,使用它的流程基本是:获取configuration配置文件-->根据配置文件创建sessionFactory-->根据sessionFactory创建session-->根据session开启事务Transaction-->创建实例化对象,然后进行持久化增删改以及查询等操作-->最后关闭事务,关闭session,关闭sessionFactory;

这个流程大概面试的时候也会经常被问到,所以与其去死记硬背这些流程,倒不如从实践中获取真理,本次测试会完整还原整个流程;

实践之后,对流程的印象会更深刻喔^-^大笑

话不多说,直接上代码:

一、整个测试的框架(简单易懂):


二、测试main方法类TestHibernate,相关的操作都已经作了详细说明:

package controller;

import java.util.List;

import org.hibernate.Criteria;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.criterion.Restrictions;
import org.hibernate.service.ServiceRegistry;

import entity.TUser;
/**
 * @author xiaohe
 * 测试hibernate(4)的增删查改功能方法;
 * 测试前提:
 *     开发工具eclipseEE(可以根据需求修改成其他开发工具);
 *     搭建好hibernate框架(网上即可查阅很多搭建框架的案例,可以百度一下),本次测试使用hibernate tools自动生成数据表和映射文件;
 *     本次测试使用mysql数据库,数据库表有两个(user和customer),本次测试只运用user,可根据需求更换数据库和数据表;
 *     加入mysql以及hibernate4等相关jar包;
 */
public class TestHibernate {
    public static void main(String[] args){
        // 实例化Configuration,  
        Configuration conf = new Configuration()  
        // 下面方法默认加载hibernate.cfg.xml文件  
                .configure();  
        // 以Configuration创建SessionFactory ,hibernate4版本之后直接使用 conf.buildSessionFactory()是已经过时了的;
        ServiceRegistry serviceRegistry=new StandardServiceRegistryBuilder()
        								.applySettings(conf.getProperties()).build();
        SessionFactory sf = conf.buildSessionFactory(serviceRegistry); 
        
        // 创建Session  
        Session sess = sf.openSession();  
        // 开始事务  
        Transaction tx = sess.beginTransaction();  
        // 创建实例对象,进行持久化操作,下面将使用多种方法进行增、删、查、改测试, 需要测试哪一种方法可去掉注释;
        TUser tuser = new TUser();  
        isadd(tuser,sess);//增
//        isdelete(tuser,sess);//删1
//        isdelete1(tuser,sess);//删2
//        isupdate(tuser,sess);//改1
//        isupdate1(tuser,sess);//改2
//        List<TUser> list = isquery1(sess);
//        System.out.println("根据年龄查询的姓名:"+list.get(0).getUserName());//查1
//        TUser user=isquery(tuser,sess);
//        System.out.println("根据id查询到的姓名:"+user.getUserName());//查2
//		  List<TUser> list = isquery2(sess);
//		  System.out.println("对象化查询的姓名:"+list.get(0).getUserName());//查3
        // 提交事务  
        tx.commit();  
        // 关闭Session  
        sess.close();  
        sf.close();  
    }  
    //增加数据
    public static boolean isadd(TUser tuser,Session sess){
        // 添加一条记录,设置用户年龄和姓名 ,如果没设置的话插入数据库默认为null
        tuser.setAge("22");
        tuser.setUserName("22");
        // 保存插入内容  
        sess.save(tuser);  
		return true; 	
    }
    //删除数据方法1
    public static boolean isdelete(TUser tuser,Session sess){
    	tuser.setId((long) 4); //删除数据需指定id才能进行删除,删除id=16的项
    	sess.delete(tuser);
		return true; 	
    }
    //删除数据方法2,使用hql
    public static boolean isdelete1(TUser tuser,Session sess){
    	String hql = "delete TUser u where u.id=?";
    	Query query = sess.createQuery(hql);
    	query.setLong(0, (long)3);
    	boolean issuccess = (query.executeUpdate()>0);
		return issuccess;
    	
    }
    //更新数据方法1
    public static boolean isupdate(TUser tuser,Session sess){
    	tuser = (TUser)sess.get(TUser.class,(long)3);//根据id获取唯一表行
    	  if(tuser != null){
    		  tuser.setUserName("xiaohe");
    		  tuser.setAge("23");
    		  sess.update(tuser);
    	  }	
    	  return true; 
    }
    //更新数据方法2,使用hql
    public static boolean isupdate1(TUser tuser,Session sess){
        String hql = "update TUser u set u.userName=?,u.age=? where u.id=?";  
        Query query = sess.createQuery(hql);  
        query.setString(0, "xiaoxue");  
        query.setString(1, "21");  
        query.setLong(2, (long)2);
        boolean issuccess = (query.executeUpdate() > 0);
    	return issuccess; //执行executeUpdate()方法更新数据库数据
    }
    //查询数据方法1
    public static TUser isquery(TUser tuser,Session sess){
    	TUser user=(TUser)sess.load(TUser.class, (long)2);
		return user;  
    }
    //查询数据方法2,使用hql
    public static List<TUser> isquery1(Session sess){
    	//注意:此处TUser是类名,而不是数据库的表名,使用数据库表名是查询不到的
    	String hql="from TUser where age='23'";
    	Query query = sess.createQuery(hql);  	
    	//如果需要使用制定的age进行查询,则使用下列方法
//        String hql = "from User u where u.id=?";  
//        Query query = sess.createQuery(hql);
//        query.setLong(0, id); 
		return query.list();  
    }
    //查询方法3,使用对象化Criteria方法查询
    public static List<TUser> isquery2(Session sess){
    	Criteria cri = sess.createCriteria(TUser.class);
    	cri.add(Restrictions.eq("age", "23"));//添加条件之后会自动执行查询方法,我们所需要做的只是获取数据
//    	cri.add(Restrictions.eq("username", "xiaohe"));//如果需要多个条件可以添加多个语句
    	/*需要说明一下eq等方法释义:
    	eq-->equal,等于
    	allEq --> 参数为Map对象,相当于多个Restrictions.eq的效果
    	gt-->great-than > 大于
    	ge --> great-equal >= 大于等于
    	lt --> less-than, < 小于
    	less-equal <= 小于等于
    	between --> 对应SQL的between子句
    	like --> 对应SQL的LIKE子句
    	...
    	*/
    	List<TUser> list = cri.list();//自动获取刚刚查询的结果集合
		return list;	
    }
}

三、实体类TUser

package entity;

public class TUser implements java.io.Serializable {

	private Long id;
	private String age;
	private String userName;

	public TUser() {
	}

	public TUser(String age, String userName) {
		this.age = age;
		this.userName = userName;
	}

	public Long getId() {
		return this.id;
	}

	public void setId(Long id) {
		this.id = id;
	}

	public String getAge() {
		return this.age;
	}

	public void setAge(String age) {
		this.age = age;
	}

	public String getUserName() {
		return this.userName;
	}

	public void setUserName(String userName) {
		this.userName = userName;
	}

}

四、说明:

1. TCustomer的实体类和TUser的实体类格式是一样的,两个实体类对应的表分别为Customer和User,他们的映射关系在TCustomer.hbm.xml和TUser.hbm.xml里面进行配置~

2. hibernate.cfg.xml为连接数据库的配置文件;hibernate.reveng.xml是hibernate对数据库表进行逆向生成POJO类可自动生成的,在生成映射代码的时候需要用到,这些都是在使用hibernate tools搭建的时候可以自动生成的,所以不必担心~

3. 为方便大家搭建框架,附上搭建框架个人认为比较好的一篇文章链接:http://www.cnblogs.com/abllyboy/archive/2010/12/23/1914577.html,希望能对搭建框架不是很懂的亲们有所帮助~

4. 附上本次测试使用到的相关jar包链接:http://download.csdn.net/detail/alan_liuyue/9696324~

5. 因为网上已经有很多hibernate测试的项目实例,所以在这里就免得多此一举,就不再上传这次测试的实例,如果确实有需要的话可以留下邮箱,可以单独发送~


五、结束语

实践是检验真理的标准;


相关文章
|
10天前
|
Java 数据库连接 API
解锁高效开发秘籍:深入探究 Hibernate 如何优雅处理一对多与多对多关系,让数据映射再无烦恼!
【9月更文挑战第3天】Hibernate 是 Java 领域中最流行的 ORM 框架之一,广泛用于处理实体对象与数据库表之间的映射。尤其在处理复杂关系如一对多和多对多时,Hibernate 提供了丰富的 API 和配置选项。本文通过具体代码示例,展示如何使用 `@OneToMany`、`@JoinColumn`、`@ManyToMany` 和 `@JoinTable` 等注解优雅地实现这些关系,帮助开发者保持代码简洁的同时确保数据一致性。
24 4
|
23天前
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
28 1
|
13天前
|
Java 数据库连接 数据库
从零到精通:揭秘 Hibernate 构建持久层服务的全过程,你离数据持久化大师还有多远?
【8月更文挑战第31天】本文详细介绍了如何从零开始使用 Hibernate 构建一个持久层服务。首先,通过在 Maven 项目中添加必要的依赖,确保项目具备使用 Hibernate 的条件。接着,配置 `hibernate.cfg.xml` 文件以连接 MySQL 数据库,并设置了基本属性。然后定义了一个简单的 `User` 实体类及其映射关系。此外,还创建了一个 `HibernateUtil` 工具类来管理 `SessionFactory`。
26 0
|
13天前
|
SQL 数据库 Java
HQL vs SQL:谁将统治数据库查询的未来?揭秘Hibernate的神秘力量!
【8月更文挑战第31天】Hibernate查询语言(HQL)是一种面向对象的查询语言,它模仿了SQL的语法,但操作对象为持久化类及其属性,而非数据库表和列。HQL具有类型安全、易于维护等优点,支持面向对象的高级特性,内置大量函数,可灵活处理查询结果。下面通过示例对比HQL与SQL,展示HQL在实际应用中的优势。例如,HQL查询“从员工表中筛选年龄大于30岁的员工”只需简单地表示为 `FROM Employee e WHERE e.age &gt; 30`,而在SQL中则需明确指定表名和列名。此外,HQL在处理关联查询时也更为直观易懂。然而,对于某些复杂的数据库操作,SQL仍有其独特优势。
22 0
|
13天前
|
数据库 Java 数据库连接
Struts 2 与 Hibernate 的完美邂逅:如何无缝集成两大框架,轻松玩转高效 CRUD 操作?
【8月更文挑战第31天】本文通过具体示例介绍了如何在 Struts 2 中整合 Hibernate,实现基本的 CRUD 操作。首先创建 Maven 项目并添加相关依赖,接着配置 Hibernate 并定义实体类及其映射文件。然后创建 DAO 接口及实现类处理数据库操作,再通过 Struts 2 的 Action 类处理用户请求。最后配置 `struts.xml` 文件并创建 JSP 页面展示用户列表及编辑表单。此示例展示了如何配置和使用这两个框架,使代码更加模块化和可维护。
24 0
|
13天前
|
Java 数据库连接 数据库
强强联手!JSF 与 Hibernate 打造高效数据访问层,让你的应用如虎添翼,性能飙升!
【8月更文挑战第31天】本文通过具体示例详细介绍了如何在 JavaServer Faces (JSF) 应用程序中集成 Hibernate,实现数据访问层的最佳实践。首先,创建一个 JSF 项目并在 Eclipse 中配置支持 JSF 的服务器版本。接着,添加 JSF 和 Hibernate 依赖,并配置数据库连接池和 Hibernate 配置文件。然后,定义实体类 `User` 和 DAO 类 `UserDAO` 处理数据库操作。
35 0
|
23天前
|
SQL Java 数据库连接
|
23天前
|
缓存 Java 数据库连接
什么是 Hibernate 查询语言或 HQL?
【8月更文挑战第21天】
37 0
|
23天前
|
Java 数据库连接 数据库