查询单个对象可以直接通过Session对象来做到,其中session这个对象提过了2种获得单个对象的方法,一个是get方法和load方法,我去看这个两个方法的时候发现这两个方法的参数是一样的,使用方式也是一样的,我们先来看看具体的使用方法:

  1. );
  2. 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就是一个字符串类型的对象。

最新文章

  1. 使用sublime编写c/c++ 总结
  2. Java设计模式(二) 观察者模式
  3. 在OS X中使用Homebrew
  4. Warp divergence
  5. ARM Linux 3.x的设备树(Device Tree)
  6. 百度Tera数据库介绍——类似cassandra,levelDB
  7. Android 标签控件
  8. GitHub上最火的40个iOS开源项目
  9. IIS充当代理转发请求到Kestrel
  10. C链栈实现
  11. 基于Bootstrap的Metro风格模板
  12. python练习三—解析xml
  13. python中// 和/有什么区别
  14. dart之旅(一)
  15. SpringMVC集成Redis
  16. [UE4]哪些数据可以保存
  17. Java核心技术之基础知识
  18. mysql 8.0 java连接报错:Unknown system variable 'query_cache_size'
  19. 2019.1.10 L223
  20. spring securiry Xml 配置 登陆

热门文章

  1. SqlServer 获取汉字的拼音首字母
  2. MySQL的binlog日志恢复(转)
  3. python 例程的一个好例子
  4. How to install Mysql in the CentOS
  5. 完美解决 IOS系统safari5.0 浏览器页面布局iframe滚动栏失效问题
  6. ThinkPad 预装win8换win7(软激活)
  7. SQL server插入数据后,如何获取自增长字段的值?
  8. Ubuntu 安装谷歌拼音输入法
  9. C++ 11 auto关键字
  10. Qt 的QString类的使用