繁体   English   中英

休眠查询计数逻辑

[英]Hibernate query Count logic

public boolean minimoUmSuperUsuario(Usuario usuario, Session sessionExterna) throws HibernateException {  
Criteria crit = sessionExterna.createCriteria(Usuario.class);

return (Long) crit.uniqueResult() > 0;  

}  

这是我需要做的:

select * from usuario where superusuario and usuarioativo = true
if  superUsuario and usuarioAtivo == 1 return true 
else false.

我不知道如何将其放在上面的方法中

更新

这就是我所做的

public boolean superUsuarioUm(Usuario usuario, Session sessionExterna) throws HibernateException {
  Criteria crit = sessionExterna.createCriteria(Usuario.class);

  crit.add(Restrictions.eq("superUsuario", usuario.isSuperUsuario()));
  crit.add(Restrictions.eq("usuarioAtivo", usuario.isUsuarioAtivo()));

  final Number value = (Number) crit.uniqueResult();

  if (value.intValue() <= 1) {
    return true;
  } else {
    return false;
  }
}

这看起来正确吗?

您只需要执行查询并获得结果。

 Criteria crit = // your criteria from your post

 final Number value = (Number) crit.uniqueResult();
 return value.intValue() <= 1;

从数据库获取结果所需要做的就是使用crit.uniqueResult() 这将为您提供许多行,但它将是一个Object 您可以将其intValue()(Number)并使用intValue()方法获取int 最后,将它与1进行比较就可以完成! :)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM