在Hibernate中Query的uniqueResult查询和Result查询有什么区别

 我来答
一骑当后
推荐于2016-01-09 · 知道合伙人数码行家
一骑当后
知道合伙人数码行家
采纳数:40298 获赞数:306443
网络、设备维护、电路、弱电检测。

向TA提问 私信TA
展开全部
  Java代码
public User get(String id){
  Session session=HibernateUtil.getSessionFactory().openSession();
  String hql="from User u where u.id = ?";
  List list=session.createQuery(hql).setString(0, id).list();
  if (list.size()==1){
  return (User)list.get(0);
  }else{
  return null;
  }
  }
  public User get(String id){ Session session=HibernateUtil.getSessionFactory().openSession(); String hql="from User u where u.id = ?"; List list=session.createQuery(hql).setString(0, id).list(); if (list.size()==1){ return (User)list.get(0); }else{ return null; } }

  昨天重读hibernate的参考手册,发现query接口提供了一个更好的方法用来获取实例,当返回的实例明确只有一个或者为null的时候。
  uniqueResult
public Object uniqueResult()throws HibernateException
返回:单个实例或者null
抛出:当返回的实例大于一个的时候的抛出NonUniqueResultException
对应的使用方法如下
Java代码
public User get(String id){
  Session session=HibernateUtil.getSessionFactory().openSession();
  String hql="from User u where u.id=?";
  return (User)session.createQuery(hql).setString(0,id).uniqueResult();
  public User get(String id){ Session session=HibernateUtil.getSessionFactory().openSession(); String hql="from User u where u.id=?"; return (User)session.createQuery(hql).setString(0,id).uniqueResult();
}
  备注:感觉不是很实用呀,当查询条件不太确定是否只有一条记录时,这时候就出麻烦了。转载,仅供参考。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式