- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
session.createSQLQuery.转载
对原生SQL查询执行的控制是通过SQLQuery接口进行的,通过执行Session.createSQLQuery()获取这个接口。下面来描述如何使用这个API进行查询。
1.标量查询(Scalar queries)
最基本的SQL查询就是获得一个标量(数值)的列表。
sess.createSQLQuery(SELECT * FROM CATS).list();
sess.createSQLQuery(SELECT ID, NAME, BIRTHDATE FROM CATS).list();
它们都将返回一个Object数组(Object[])组成的List,数组每个元素都是CATS表的一个字段值。Hibernate会使用ResultSetMetadata来判定返回的标量值的实际顺序和类型。
如果要避免过多的使用ResultSetMetadata,或者只是为了更加明确的指名返回值,可以使用addScalar()。
sess.createSQLQuery(SELECT * FROM CATS).addScalar(ID, Hibernate.LONG).addScalar(NAME, Hibernate.STRING).addScalar(BIRTHDATE, Hibernate.DATE)
这个查询指定了:
SQL查询字符串
要返回的字段和类型
它仍然会返回Object数组,但是此时不再使用ResultSetMetdata,而是明确的将ID,NAME和BIRTHDATE按照Long,String和Short类型从resultset中取出。同时,也指明了就算query是使用*来查询的,可能获得超过列出的这三个字段,也仅仅会返回这三个字段。
对全部或者部分的标量值不设置类型信息也是可以的。
sess.createSQLQuery(SELECT * FROM CATS) .addScalar(ID, Hibernate.LONG) .addScalar(NAME) .addScalar(BIRTHDATE)
基本上这和前面一个查询相同,只是此时使用ResultSetMetaData来决定NAME和BIRTHDATE的类型,而ID的类型是明确指出的。
关于从ResultSetMetaData返回的java.sql.Types是如何映射到Hibernate类型,是由方言(Dialect)控制的。假若某个指定的类型没有被映射,或者不是你所预期的类型,你可以通过Dialet的registerHibernateType调用自行定义。
2.实体查询(Entity queries)
上面的查询都是返回标量值的,也就是从resultset中返回的“裸”数据。下面展示如何通过addEntity()让原生查询返回实体对象。
sess.createSQLQuery(SELECT * FROM CATS).addEntity(Cat.class);?
sess.createSQLQuery(SELECT ID, NAME, BIRTHDATE FROM CATS).addEntity(Cat.class);
这个查询指定:
SQL查询字符串
要返回的实体
假设Cat被映射为拥有ID,NAME和BIRTHDATE三个字段的类,以上的两个查询都返回一个List,每个元素都是一个Cat实体。
假若实体在映射时有一个many-to-one的关联指向另外一个实体,在查询时必须也返回那个实体,否则会导致发生一个column not found的数据库错误。这些附加的字段可以使用*标注来自动返回,但我们希望还是明确指明,看下面这个具有指向Dog的many-to-one的例子:
sess.createSQLQuery(SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS).addEntity(Cat.class);
这样cat.getDog()就能正常运作。
?
下面的暂时没需求
16.1.3. 处理关联和集合类(Handling associations and collections)
通过提前抓取将Dog连接获得,而避免初始化proxy带来的额外开销也是可能的。这是通过addJoin()方法进行的,这个方法可以让你将关联或集合连接进来。
sess.createSQLQuery(SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID).addEntity(cat, Cat.class).addJoin(cat.dog);
上面这个例子中,返回的Ca
您可能关注的文档
- 生态工程的实例和发展前景课件分析.ppt
- 上海交通大学大学物理A类第2章1重点.ppt
- 食用菌栽培概述分析.ppt
- 食用菌栽培整理重点.docx
- 上海交通大学大学物理A类第一章1分析.ppt
- 食用昆虫的可利用性重点.doc
- 生态工程学论文重点.docx
- 生态环境问题分析.ppt
- 上海交通大学管理学原理课件ch01管理概述分析.ppt
- 食用油的市场调查分析.ppt
- 上海交通大学遗传学课件6链饱霉分析.ppt
- 使用合并节点、MPC接触、节点耦合、约束方程等的一个例子分析.docx
- 上海交通大学遗传学课件遗传与发育分析.ppt
- 上海教材高中数学知识点总结(最全)分析.doc
- 生物:1.2.4《多细胞生物体的结构层次》课件jb(济南版七年级上)重点.ppt
- 生物:1.2《人的生殖》课件5(人教版七年级下)2重点.ppt
- 示范教案一(春秋战国的纷争1课时)分析.doc
- 示范课(优秀)苏教版必修3体温调节重点.ppt
- 世纪金榜·2016高考地理一轮课时提升作业(十五)1.1人口的数量变化、人口的合理容量分析.doc
- 上海科技出版社八、九年级物理全册知识点分析.doc
原创力文档


文档评论(0)