📄 querysql.html
字号:
<return alias="person" class="eg.Person"/> <return-join alias="address" property="person.mailingAddress"/></resultset><sql-query name="personsWith" resultset-ref="personAddress"> SELECT person.NAME AS {person.name}, person.AGE AS {person.age}, person.SEX AS {person.sex}, adddress.STREET AS {address.street}, adddress.CITY AS {address.city}, adddress.STATE AS {address.state}, adddress.ZIP AS {address.zip} FROM PERSON person JOIN ADDRESS adddress ON person.ID = address.PERSON_ID AND address.TYPE='MAILING' WHERE person.NAME LIKE :namePattern</sql-query></pre><div class="sect2" lang="zh-cn"><div class="titlepage"><div><div><h3 class="title"><a name="propertyresults"></a>16.3.1. 使用return-property来明确地指定字段/别名</h3></div></div><div></div></div><p> 使用<tt class="literal"><return-property></tt>你可以明确的告诉Hibernate使用哪些字段别名,这取代了使用<tt class="literal">{}</tt>-语法 来让Hibernate注入它自己的别名. </p><pre class="programlisting"><sql-query name="mySqlQuery"> <return alias="person" class="eg.Person"> <return-property name="name" column="myName"/> <return-property name="age" column="myAge"/> <return-property name="sex" column="mySex"/> </return> SELECT person.NAME AS myName, person.AGE AS myAge, person.SEX AS mySex, FROM PERSON person WHERE person.NAME LIKE :name</sql-query></pre><tt class="literal"><return-property></tt>也可用于多个字段,它解决了使用<tt class="literal">{}</tt>-语法不能细粒度控制多个字段的限制 <pre class="programlisting"><sql-query name="organizationCurrentEmployments"> <return alias="emp" class="Employment"> <return-property name="salary"> <return-column name="VALUE"/> <return-column name="CURRENCY"/> </return-property> <return-property name="endDate" column="myEndDate"/> </return> SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer}, STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate}, REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY FROM EMPLOYMENT WHERE EMPLOYER = :id AND ENDDATE IS NULL ORDER BY STARTDATE ASC</sql-query></pre><p> 注意在这个例子中,我们使用了<tt class="literal"><return-property></tt>结合<tt class="literal">{}</tt>的注入语法. 允许用户来选择如何引用字段以及属性. </p><p> 如果你映射一个识别器(discriminator),你必须使用<tt class="literal"><return-discriminator></tt> 来指定识别器字段 </p></div><div class="sect2" lang="zh-cn"><div class="titlepage"><div><div><h3 class="title"><a name="sp_query"></a>16.3.2. 使用存储过程来查询</h3></div></div><div></div></div><p> Hibernate 3引入了对存储过程查询(stored procedure)和函数(function)的支持.以下的说明中,这二者一般都适用。 存储过程/函数必须返回一个结果集,作为Hibernate能够使用的第一个外部参数. 下面是一个Oracle9和更高版本的存储过程例子.</p><pre class="programlisting">CREATE OR REPLACE FUNCTION selectAllEmployments RETURN SYS_REFCURSOR AS st_cursor SYS_REFCURSOR; BEGIN OPEN st_cursor FOR SELECT EMPLOYEE, EMPLOYER, STARTDATE, ENDDATE, REGIONCODE, EID, VALUE, CURRENCY FROM EMPLOYMENT; RETURN st_cursor; END;</pre><p> 在Hibernate里要要使用这个查询,你需要通过命名查询来映射它. </p><pre class="programlisting"><sql-query name="selectAllEmployees_SP" callable="true"> <return alias="emp" class="Employment"> <return-property name="employee" column="EMPLOYEE"/> <return-property name="employer" column="EMPLOYER"/> <return-property name="startDate" column="STARTDATE"/> <return-property name="endDate" column="ENDDATE"/> <return-property name="regionCode" column="REGIONCODE"/> <return-property name="id" column="EID"/> <return-property name="salary"> <return-column name="VALUE"/> <return-column name="CURRENCY"/> </return-property> </return> { ? = call selectAllEmployments() }</sql-query></pre><p> 注意存储过程当前仅仅返回标量和实体.现在不支持<tt class="literal"><return-join></tt>和<tt class="literal"><load-collection></tt> </p><div class="sect3" lang="zh-cn"><div class="titlepage"><div><div><h4 class="title"><a name="querysql-limits-storedprocedures"></a>16.3.2.1. 使用存储过程的规则和限制</h4></div></div><div></div></div><p> 为了在Hibernate中使用存储过程,你必须遵循一些规则.不遵循这些规则的存储过程将不可用.如果你仍然想要使用他们, 你必须通过<tt class="literal">session.connection()</tt>来执行他们.这些规则针对于不同的数据库.因为数据库 提供商有各种不同的存储过程语法和语义. </p><p> 对存储过程进行的查询无法使用<tt class="literal">setFirstResult()/setMaxResults()</tt>进行分页。 </p><p>建议采用的调用方式是标准SQL92: <tt class="literal">{ ? = call functionName(<parameters>) }</tt> 或者 <tt class="literal">{ ? = call procedureName(<parameters>}</tt>.原生调用语法不被支持。</p><p> 对于Oracle有如下规则:
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -