使用Hibernate sessionFactory工具类来对数据的增删改查

本文通过Java Hibernate框架演示了基本的CRUD操作,包括根据ID查询、插入、删除员工数据等,并展示了使用HQL查询语言和Criteria API进行数据检索的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.ask.test;
import java.util.Date;
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.junit.Before;
import org.junit.Test;
import com.ask.pojo.Emp;
import com.ask.util.HibernateUtil;
public class EmpTest {

private SessionFactory sessionFactory;
@Before
public void setUp() throws Exception {
//使用hibernateUtil工具类来创建单例的sessionFactory 对象
//再使用sessionFactory 对象来创建session
//工具类提供一个创建session的方法
sessionFactory=HibernateUtil.getSessionFactory();
}
//根据用户id查询;
@Test
public void testSelectById() {
Session session=sessionFactory.openSession();
// 根据id查询emp数据
Emp e = (Emp) session.get(Emp.class, 1);
System.out.println(e);
}
//增加;
@Test
public void testInsert(){
Session session=sessionFactory.openSession();
Transaction tx=session.beginTransaction();
Emp e=new Emp("lucy","1",new Date());
session.save(e);
tx.commit();
session.close();
//sessionFactory.close();

}
//删除;
@Test
public void testDelete(){
Session session=sessionFactory.openSession();
Transaction tx=session.beginTransaction();
Emp e=(Emp) session.get(Emp.class,3);
session.delete(e);
tx.commit();
session.close();
}

//根据id唯一进行查询;
@Test
public void testSelectUnique() {
Session session=sessionFactory.openSession();
String hql="From Emp e where e.id=:id";
Query query = session.createQuery(hql);
query.setInteger("id",3);
Emp e =(Emp) query.uniqueResult();
System.out.println(e);
session.close();

}
//查询分页;
@Test
public void testSelectList() {
Session session=sessionFactory.openSession();
String hql="From Emp";
Query query = session.createQuery(hql);
List<Emp> e=query.list();
for (Emp emp : e) {
System.out.println(emp);
}
session.close();
}

//criteria分页查询;
@Test
public void testSelectQBCList() {
Session session = sessionFactory.openSession();
Criteria criteria= session.createCriteria(Emp.class);
criteria.setFirstResult(0);
criteria.setMaxResults(3);
List<Emp> e=criteria.list();
for (Emp emp : e) {
System.out.println(emp);
}
session.close();
}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值