hibernate分页查询和方言

本文介绍了如何在Hibernate中利用方言特性实现跨数据库的分页查询,通过配置<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>,可以自动生成适应不同数据库的SQL,简化了开发过程。

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

1. 方言的作用 

*  1). 方言会根据不同的数据库来生成不同的sql语句

        所以做分页的时候不用考虑跨数据库的问题

*  2). 数据类型映射, 可以匹配不同的数据类型
        varchar  varchar2 都会映射成String

2. 在hibernate.cfg.xml中配置方言
<!-- 配置数据库的方言,让hibernate知道连接的是那个数据库 -->

<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>


3. 分页查询

public class PageDemo {
	@Test
	public void testPage(){
		Session s = HibernateUtils.getSession();
		s.beginTransaction();

        // 方法1: 
		// Criteria c = s.createCriteria(Book.class);
		// 以下设置分页
		// c.setFirstResult(3);		     //从第3行开始 
		// c.setMaxResults(2);			//最多查询几行 ,上面两句相当于:   limit 3,2

        // 方法2: hql
		// String hql = "from Book";
		// Query q = s.createQuery(hql);
		// q.setFirstResult(3);
		// q.setMaxResults(3);

        // 方法3: 纯sql
		String sql = "select * from book";  //list<Object[]>
		SQLQuery q = s.createSQLQuery(sql);
		q.setFirstResult(3);
		q.setMaxResults(3);
		q.setResultTransformer(Transformers.aliasToBean(Book.class));
		
		List<Book> list = q.list(); 
		System.err.println(">>:"+list);
		s.getTransaction().commit();
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值