首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | 镜像站
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
Linux资讯 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>编程开发>java>Java基础>正文

数据库相关:小结Hibernate的查询方式

http://www.oklinux.cn  2008-01-20  来源: 赛迪网 huanglz  会员收藏  游客收藏  【 】 

1. get() and load()

  session.get(Clazz, id);
  session.load(Clazz, id);

  说明: load()与get()的区别
  请注重假如没有匹配的数据库记录,load()方法可能抛出无法恢复的异常(unrecoverable

exception)。 假如类的映射使用了代理(proxy),load()方法会返回一个未初始化的代理,直到你调用

该代理的某方法时才会去访问数据库。 若你希望在某对象中创建一个指向另一个对象的关联,又不想在

从数据库中装载该对象时同时装载相关联的那个对象,那么这种操作方式就用得上的了。 假如为相应类

映射关系设置了batch-size, 那么使用这种操作方式答应多个对象被一批装载(因为返回的是代理,无

需从数据库中抓取所有对象的数据)。
  假如你不确定是否有匹配的行存在,应该使用get()方法,它会马上访问数据库,假如没有对应的行,会返回null。

  2. HQL

  // 返回一行记录
  String hql = "from TOrder o where o.id = ?";
  TOrder o = (TOrder) s.createQuery(hql)
    .setParameter(0, orderId)
    .uniqueResult();

  // 命名参数
  Query q = sess.createQuery("from DomesticCat cat where cat.name = :name");
  q.setString("name", "Fritz");

  // 位置参数
  Query q = sess.createQuery("from DomesticCat cat where cat.name = ?");
  q.setString(0, "Izi");

  // 命名参数列表
  Query q = sess.createQuery("from DomesticCat cat where cat.name in (:namesList)");
  q.setParameterList("namesList", names);

  // 分页查询
  Query q = sess.createQuery("from DomesticCat cat");
  q.setFirstResult(20);
  q.setMaxResults(10);
  List cats = q.list();

  3. Criteria

  List cats = sess.createCriteria(Cat.class)
   .add( Restrictions.like("name", "Fritz%") )
   .add( Restrictions.or(
   Restrictions.eq( "age", new Integer(0) ),
   Restrictions.isNull("age")
   ) )
   .addOrder( Order.asc("name") )
   .addOrder( Order.desc("age") )
   .list();

  4. Native SQL

  String treeSql = ""
   "select , level from tree t "
   " start with t.parent_id = 0 "
   " connect by prior t.id = t.parent_id";

  List result = session.createSQLQuery(treeSql)
   .addEntity("t", Tree.class)
   .addScalar("level", Hibernate.INTEGER)
   .list();

  5. Named SQL queries(不推荐)

  6. filter(不推荐)

  7. Detached queries(还没测试)
  The DetachedCriteria class lets you create a query outside the scope of a session, and

then later execute it using some arbitrary Session


上一篇:Java GUI:Java布局管理器使用方法探讨   下一篇:进阶--开发J2EE应用应遵循的几点原则


收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·Java GUI:Java布局管理器使用方法探讨
·高级:Cookie,httpsession类使用概述
·J2SE综合介绍:与你一起讨论AJAX进一阶应用
·服务器及中间件:JBoss4.0数据源配置大全
·I/O及网络--一个简单的文件传送代码
·通过Hibernate_tool生成代码和映射文件
·基于AJAX的动态树型结构的设计与实现
·J2ME综合--谈谈J2ME的几个重要的功能
·J2SE综合:浅析Java语言中两种异常的差别
·J2ME综合--J2ME应用程序内存优化三招
·J2SE综合--Java 5.0 多线程编程实践
·I/O及网络--MD5加密及Java的实现方式
·J2ME综合--JAR文件包及jar命令详解
·J2SE综合:两种Java容器类List和Set分析
·浅析Spring2.0中新的Bean类型实现原理
·进阶-不使用泛型如何保证程序的可读性
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·Java入门:状态对象--数据库的替代者
·Java语言怎样调用外部应用程序
·Java语言深入--关于Java语言的内存泄漏
·JSP/Servlet/JSF:Servlet/JSP配置详解
·进阶-怎样使用AJAX进行WEB应用程序开发
·基础:J2ME程序开发之新手入门九大要点
·Java入门--Java语言接口与继承的本质
·JAVA进阶--如何提升JSP应用程序的效率
·对Java中四种XML解析技术之不完全测试
·编写高级 JScript应用代码
·JSP/Servlet/JSF--对标签库的深入研究
·Java入门--关于字符串分割的两种方法
  阅读排行
·使用AJAX技术实现网页无闪自动局部刷新
·快速教您Apache Tomcat SSL的配置
·Java语言深入--java调用C/C 的过程
·用JSP JavaScript打造二级级联下拉菜单
·JAVA进阶--线程运行栈信息的获取讲解
·J2SE综合--JAVA实现把汉字转化成拼音
·使用WEBWORK实现文件上传方法实例详解
·一个非常有趣的使用spring框架AOP例子
·关于java中相对路径,绝对路径问题总结
·高级:lucene全文检索应用示例及代码简
·详细讲解Struts构架中action的跳转大全
·在Weblogic上配置JMS服务的方法
·Hibernate配置文件中的映射元素详解
·对Java中四种XML解析技术之不完全测试
·基于AJAX的动态树型结构的设计与实现
网摘收藏: