Hibernate 查询小结

 HQL 

  // 返回一行记录 
  String hql = "from TOrder o where o.id = ?"; 
  TOrder o = (TOrder) s.createQuery(hql) 
    .setParameter(0, orderId) 
    .uniqueResult(); 

  // 命名参数 
  Query q = sess.createQuery("from DomesticCat cat where cat.name = :name"); 
  q.setString("name", "Fritz"); 

  // 位置参数 
  Query q = sess.createQuery("from DomesticCat cat where cat.name = ?"); 
  q.setString(0, "Izi"); 

  // 命名参数列表 
  Query q = sess.createQuery("from DomesticCat cat where cat.name in (:namesList)"); 
  q.setParameterList("namesList", names); 

  // 分页查询 
  Query q = sess.createQuery("from DomesticCat cat"); 
  q.setFirstResult(20); 
  q.setMaxResults(10); 
  List cats = q.list(); 

  3. Criteria 

  List cats = sess.createCriteria(Cat.class) 
   .add( Restrictions.like("name", "Fritz%") ) 
   .add( Restrictions.or( 
   Restrictions.eq( "age", new Integer(0) ), 
   Restrictions.isNull("age") 
   ) ) 
   .addOrder( Order.asc("name") ) 
   .addOrder( Order.desc("age") ) 
   .list(); 

  4. Native SQL 

  String treeSql = "" + 
   "select , level from tree t " + 
   " start with t.parent_id = 0 " + 
   " connect by prior t.id = t.parent_id"; 

  List result = session.createSQLQuery(treeSql) 
   .addEntity("t", Tree.class) 
   .addScalar("level", Hibernate.INTEGER) 
   .list(); 
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值