使用hibernate的get方法查询数据库,是不是只能根据id字段查询?

来源:百度知道 编辑:UC知道 时间:2024/05/17 05:51:31
使用hibernate的get方法查询数据库,是不是只能根据id字段查询?我的表中的username也是唯一的,我想根据username查询而不是id查询是否可以使用get方法?谢谢

初学者,如果问题比较弱智请谅解。

不行的,get(类名,id)一定是这样用的楼主,get和load都只能根据id来查询某个对象,假设是User类,你已经得到了hibernate中的session对象
那么User user=(User)session.get(类名,id);
如果你要用username查询那么楼主,你就自己写一个hql语句
,String hql="from Users as u where u.username=?";
剩下的相信楼主应该可以自己解决了吧

  最基本的查询就是获得一个标量(数值)的列表。
  1sess.createSQLQuery("SELECT * FROM CATS").list();
  2sess.createSQLQuery("SELECT ID, NAME, BIRTHDATE FROM CATS").list();
  将返回一个Object数组(Object[])组成的List,数组每个元素都是CATS表的一个字段值。Hibernate会使用ResultSetMetadata来判定返回的标量值的实际顺序和类型。
  如果要避免过多的使用ResultSetMetadata,或者只是为了更加明确的指名返回值,可以使用addScalar()。

YES
NO