Hibernate查询数据

本文介绍了一个使用Hibernate框架实现的学生信息管理系统。该系统包括学生信息的增删查改操作,并演示了如何通过SQL和HQL进行数据查询。

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

package com.ittx.hibernate002.model;

import java.util.Date;
import java.util.List;

import org.hibernate.Query;
import org.hibernate.SQLQuery;
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.service.ServiceRegistry;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;

public class StudentTest {
	SessionFactory sessionFactory;
	Transaction transaction;
	Session session;

	@Before
	public void setUp() throws Exception {
		// 读取hibernate.cfg.xml文件
		Configuration config = new Configuration().configure();
		ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().applySettings(config.getProperties())
				.build();
		// 建立SessionFactory
		sessionFactory = config.buildSessionFactory(serviceRegistry);
//		session = sessionFactory.openSession();
		session = sessionFactory.getCurrentSession();
		transaction = session.beginTransaction();
	}
	
	@After
	public void tearDown() throws Exception {
		transaction.commit();
//		session.close();
//		sessionFactory.close();
	}

	@Test
	public void testSaveStudent() {
		Student student = new Student(1001, "小丽", 18,"男",new Date());
		session.save(student);
		
		student = new Student(1002, "小明", 23,"女",new Date());
		session.save(student);
		
//		Student student = new Student(1001, "小明", 23,"女",new Date());
//		session.delete(student);
		
	}
	/**
	 * SQL方法
	 * 
	 */
	@Test
	public void testQueryStudent(){
		String sql = "select * from student where age=18 or number=1002 order by age DESC";
		SQLQuery sqlQuery = session.createSQLQuery(sql).addEntity(Student.class);
		List<Student> list = sqlQuery.list();
		for(Student student:list){
			System.out.println(student);
		}
	}
	/**
	 * HSQL方法
	 */
	@Test
	public void testHQLStudent(){
		String hsql = "FROM Student";
		Query query = session.createQuery(hsql);
		List<Student> list = query.list();
		for(Student student:list){
			System.out.println(student);
		}
	}
	/**
	 * HSQL
	 */
	@Test
	public void testHQLStudentValue(){
		String hsql = "SELECT count(*) FROM Student";
		Query query = session.createQuery(hsql);
		Long r = (Long) query.uniqueResult();
		System.out.println(r);
	}
	/**
	 * 查找指定属性记录
	 * 1.创建包含查询属性构造方法
	 * 2.若查询结果唯一,用uniqueResult(),有多条结果,用list()
	 */
	@Test
	public void testHQLStudentSelect(){
		String hsql = "SELECT new Student(s.name,s.number) FROM Student AS s where s.number=:num";
		Query query = session.createQuery(hsql);
		query.setParameter("num", 1001);
		Student r = (Student) query.uniqueResult();
		System.out.println(r);
	}
	
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值