网站导航网学 原创论文 原创专题 网站设计 最新系统 原创论文 论文降重 发表论文 论文发表 UI设计定制 论文答辩PPT格式排版 期刊发表 论文专题
返回网学首页
网学原创论文
最新论文 推荐专题 热门论文 论文专题
当前位置: 网学 > 交易代码 > SQL语法 > 正文

17NativeSQL查询

论文降重修改服务、格式排版等 获取论文 论文降重及排版 论文发表 相关服务

【网学网提醒】:以下是网学会员为您推荐的17NativeSQL查询,希望本篇文章对您学习有所帮助。


    第17章NativeSQL查询
    上一页下一页
    --------------------------------------------------------------------------------
    第17章NativeSQL查询
    你也可以使用你的数据库的NativeSQL语言来查询数据。这对你在要使用数据库的某些特性的时候(比如说在查询提示或者Oracle中的CONNECT关键字),这是非常有用的。这就能够扫清你把原来直接使用SQL/JDBC的程序迁移到基于Hibernate应用的道路上的障碍。
    Hibernate3允许你使用手写的sql来完成所有的create,update,delete,和load操作(包括存储过程)
    17.1.创建一个基于SQL的Query
    SQL查询是通过SQLQuery接口来控制的,它是通过调用Session.createSQLQuery()方法来获得
    Listcats=sess.createSQLQuery("select{cat.*}fromcatscat")
    .addEntity("cat",Cat.class);
    .setMaxResults(50);
    .list();
    这个查询指定了:
    SQL查询语句,它带一个占位符,可以让Hibernate使用字段的别名.
    查询返回的实体,和它的SQL表的别名.
    addEntity()方法将SQL表的别名和实体类联系起来,并且确定查询结果集的形态。
    addJoin()方法可以被用于载入其他的实体和集合的关联,TODO:examples!
    原生的SQL查询可能返回一个简单的标量值或者一个标量和实体的结合体。
    Doublemax=(Double)sess.createSQLQuery("selectmax(cat.weight)asmaxWeightfromcatscat")
    .addScalar("maxWeight",Hibernate.DOUBLE);
    .uniqueResult();
    17.2.别名和属性引用
    上面使用的{cat.*}标记是"所有属性"的简写.你可以显式地列出需要的字段,但是你必须让Hibernate为每一个属性注入字段的别名.这些字段的站位符是以字段别名为前导,再加上属性名.在下面的例子里,我们从一个其他的表(cat_log)中获取Cat对象,而非Cat对象原本在映射元数据中声明的表.注意我们甚至在where子句中也可以使用属性别名.对于命名查询,{}语法并不是必需的.你可以在第17.3节“命名SQL查询”得到更多的细节.
    Stringsql="selectcat.originalIdas{cat.id},"+
    "cat.mateidas{cat.mate},cat.sexas{cat.sex},"+
    "cat.weight*10as{cat.weight},cat.nameas{cat.name}"+
    "fromcat_logcatwhere{cat.mate}=:catId"
    
    ListloggedCats=sess.createSQLQuery(sql)
    .addEntity("cat",Cat.class)
    .setLong("catId",catId)
    .list();
    注意:如果你明确地列出了每个属性,你必须包含这个类和它的子类的属性!anditssubclasses!
    17.3.命名SQL查询
    可以在映射文档中定义查询的名字,然后就可以象调用一个命名的HQL查询一样直接调用命名SQL查询.在这种情况下,我们不需要调用addEntity()方法.
    
    
    SELECTperson.NAMEAS{person.name},
    person.AGEAS{person.age},
    
    person.SEXAS{person.sex}
    FROMPERSONpersonWHEREperson.NAMELIKE'Hiber%'
    
    Listpeople=sess.getNamedQuery("mySqlQuery")
    .setMaxResults(50)
    .list();
    一个命名查询可能会返回一个标量值.你必须使用元素来指定字段的别名和Hibernate类型
    
    
    
    SELECTp.NAMEASname,
    p.AGEASage,
    FROMPERSONpWHEREp.NAMELIKE'Hiber%'
    
    元素分别用作外连接和定义那些初始化集合的查询
    17.3.1.使用return-property来明确地指定字段/别名
    使用你可以明确的告诉Hibernate使用哪些字段,这和使用{}-语法来让Hibernate注入它自己的别名是相反的.
    
    
    
    
    
    
    SELECTperson.NAMEASmyName,
    person.AGEASmyAge,
    person.SEXASmySex,
    FROMPERSONpersonWHEREperson.NAMELIKE:name
    
    也可用于多个字段,它解决了使用{}-语法不能细粒度控制多个字段的限制
    
    
    
    
    
    

    
    
    SELECTEMPLOYEEAS{emp.employee},EMPLOYERAS{emp.employer},
    STARTDATEAS{emp.startDate},ENDDATEAS{emp.endDate},
    REGIONCODEas{emp.regionCode},EIDAS{emp.id},VALUE,CURRENCY
    FROMEMPLOYMENT
    WHEREEMPLOYER=:idANDENDDATEISNULL
    ORDERBYSTARTDATEASC
    
    注意在这个例子中,我们使用了结合{}的注入语法.允许用户来选择如何引用字段以及属性.
    如果你映射一个识别器(discriminator),你必须使用来指定识别器字段
    17.3.2.使用存储过程来查询
    Hibernate3引入了对存储过程查询的支持.存储过程必须返回一个结果集,作为Hibernate能够使用的第一个外部参数.下面是一个Oracle9和更高版本的存储过程例子.
    CREATEORREPLACEFUNCTIONselectAllEmployments
    RETURNSYS_REFCURSOR
    AS
    st_cursorSYS_REFCURSOR;
    BEGIN
    OPENst_cursorFOR
    SELECTEMPLOYEE,EMPLOYER,
    STARTDATE,ENDDATE,
    REGIONCODE,EID,VALUE,CURRENCY
    FROMEMPLOYMENT;
    RETURNst_cursor;
    END;
    在Hibernate里要要使用这个查询,你需
    要通过命名查询来映射它.
    
    
    
    
    
    
    
    
    
    
    
    

    
    {?=callselectAllEmployments()}
    
    注意存储过程当前仅仅返回标量和实体.现在不支持
    17.3.2.1.使用存储过程的规则和限制
    为了在Hibernate中使用存储过程,你必须遵循一些规则.不遵循这些规则的存储过程将不可用.如果你仍然想要使用他们,你必须通过session.connection()来执行他们.这些规则针对于不同的数据库.因为数据库提供商有各种不同的存储过程语法和语义.
    对存储过程进行的查询无法使用setFirstResult()/setMaxResults()进行分页。
    对于Oracle有如下规则:
    存储过程必须返回一个结果集.它通过返回SYS_REFCURSOR实现(在Oracle9或10),在Oracle里你需要定义一个REFCURSOR类型
    推荐的格式是{?=callprocName()}或{?=callprocName}(这更像是Oracle规则而不是Hibernate规则)
    对于Sybase或者MSSQLserver有如下规则:
    存储过程必须返回一个结果集。.注意这些servers可能返回多个结果集以及更新的数目.Hibernate将取出第一条结果集作为它的返回值,其他将被丢弃。
    如果你能够在存储过程里设定SETNOCOUNTON,这可能会效率更高,但这不是必需的。
    17.4.定制SQL用来create,update和delete
    Hibernate3能够使用定制的SQL语句来执行create,update和delete操作。在Hibernate中,持久化的类和集合已经包含了一套配置期产生的语句(insertsql,deletesql,updatesql等等),这些映射标记,,and重载了这些语句。
    
    
    
    
    
    INSERTINTOPERSON(NAME,ID)VALUES(UPPER(?),?)
    UPDATEPERSONSETNAME=UPPER(?)WHEREID=?
    DELETEFROMPERSONWHEREID=?
    
    这些SQL直接在你的数据库里执行,所以你可以自由的使用你喜欢的任意语法。但如果你使用数据库特定的语法,这当然会降低你映射的可移植性。
    如果设定callable,则能够支
    持存储过程了。
    
    
    
    
    
    {callcreatePerson(?,?)}

    {?=calldeletePerson(?)}
    {?=callupdatePerson(?,?)}
    
    参数的位置顺序是非常重要的,他们必须和Hibernate所期待的顺序相同。
    你能够通过设定日志调试级别为org.hiberante.persister.entity,来查看Hibernate所期待的顺序。在这个级别下,Hibernate将会打印出create,update和delete实体的静态SQL。如果想看到预想中的顺序。记得不要将定制SQL包含在映射文件里,因为他们会重载Hibernate生成的静态SQL。
    在大多数情况下(最好这么做),存储过程需要返回插入/更新/删除的行数,因为Hibernate对语句的成功执行有些运行时的检查。Hibernate常会把进行CUD操作的语句的第一个参数注册为一个数值型输出参数。
    CREATEORREPLACEFUNCTIONupdatePerson(uidINNUMBER,unameINVARCHAR2)
    RETURNNUMBERIS
    BEGIN
    updatePERSON
    set
    NAME=uname,
    where
    ID=uid;
    returnSQL%ROWCOUNT;
    ENDupdatePerson;
    17.5.定制装载SQL
    你可能需要声明你自己的SQL(或HQL)来装载实体
    
    
    SELECTNAMEAS{p.name},IDAS{p.id}FROMPERSONWHEREID=?FORUPDATE
    
    这只是一个前面讨论过的命名查询声明,你可以在类映射里引用这个命名查询。
    
    
    
    
    
    
    
    这也可以用于存储过程
    TODO:未完成的例子
    
    
    SELECT{empcol.*}
    FROMEMPLOYMENTempcol
    WHEREEMPLOYER=:id
    ORDERBYSTARTDATEASC,EMPLOYEEASC
    
    
    
    
    SELECTEMPLOYEEAS{emp.employee},EMPLOYERAS{emp.employer},
    STARTDATEAS{emp.startDate},ENDDATEAS{emp.endDate},
    REGIONCODEas{emp.regionCode},IDAS{emp.id}
    FROMEMPLOYMENT
    WHEREEMPLOYER=:idANDENDDATEISNULL
    ORDERBYSTARTDATEASC
    
    --------------------------------------------------------------------------------
    上一页上一级下一页
    第16章条件查询(CriteriaQueries)起始页第18章过滤数据
    
  • 上一篇资讯: 19、PLSQL语法基础
  • 下一篇资讯: 13个SQL优化技巧
  • 设为首页 | 加入收藏 | 网学首页 | 原创论文 | 计算机原创
    版权所有 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
    Copyright 2008-2020 myeducs.Cn www.myeducs.Cn All Rights Reserved 湘ICP备09003080号 常年法律顾问:王律师