在hibernate中查询单个对象的方法,get()、load()、uniqueResult()
查询单个对象可以直接通过Session对象来做到,其中session这个对象提过了2种获得单个对象的方法,一个是get方法和load方法,我去看这个两个方法的时候发现这两个方法的参数是一样的,使用方式也是一样的,我们先来看看具体的使用方法:
Object obj = session.get(user.getClass(), 100);
Object obj1 = session.load(user.getClass(), 200);
这个方法的使用方式看起来都一样都能获取到一个object对象,其实这两个方法有很大的区别:
1.用get方法的时候是session会立即创建一个连接并获取数据,用load方法的时候是session不会去创建连接然后去获取数据,它会在你去获取你要查询的对象的属性的时候才会去创建连接和获取数据,所以说,用load的话,我们获取到的obj1里面其实没有任何数据,只有我们obj1.getXXX();的时候才会去获取数据库的数据,但是如果我们在没有去获取它的属性以前,就关闭了session的话,就会报session已经关闭了。
2.用load方法的时候如果查询出来的对象里面又包含一个对象属性呢,当我们查询出来的时候这个对象里面的对象属性是为null的,当具体要getXXX对象属性的时候才会去访问。
3.用get的话如果传入的id不存在会返回空值,load返回一个代理类,如果id不存在,报id不存在异常
上面的两种方法都要通过主键进行查询,其他字段不能够使用。而我们在平常项目中很多时候需要通过一个唯一约束条件得到一个对象。比如通过用户名得到密码,这个时候可以使用uniqueResult()方法来获取。比如
Query q = session.createQuery("select t.password from TUserLogin t where t.username='"+loginUser+"'");
Object o = q.uniqueResult();
这个时候o就是一个字符串类型的对象。