Hibernate的<query>标签使用

本文介绍如何在Hibernate中通过配置文件定义SQL查询,避免硬编码带来的不便。示例展示了如何配置User类对应的表及字段,并通过&lt;query&gt;元素定义参数化的SQL查询语句。

Hibernate也可以将查询的SQL语句写在配置文件里,避免硬编码下面是个例子:

<?xml version="1.0"?> 
<!DOCTYPE hibernate-mapping 
    PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" 
    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"> 

<hibernate-mapping> 

    <class name="onlyfun.caterpillar.User" table="USER"> 

        <id name="id" type="string"> 
            <column name="user_id" sql-type="char(32)" /> 
            <generator class="uuid.hex"/> 
        </id> 

        <property name="name" type="string" not-null="true"> 
            <column name="name" length="16" not-null="true"/> 
        </property> 

        <property name="sex" type="char"/> 

        <property name="age" type="int"/> 

    </class> 

    <query name="onlyfun.caterpillar.queryUser"> 
        <![CDATA[ 
            select user.name from User as user where user.age = :age and user.sex = :sex 
        ]]> 
    </query> 

</hibernate-mapping>

 在程序中引用<query>的name属性可以访问到sql:

Query query = session.getNamedQuery("onlyfun.caterpillar.queryUser"); 
query.setInteger("age", 25); 
query.setCharacter("sex", 'M'); 

List names = query.list(); 
for (ListIterator iterator = names.listIterator(); iterator.hasNext(); ) { 
    String name = (String) iterator.next(); 
    System.out.println("name: " + name); 
}

 

 

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 2.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"> <hibernate-mapping package="com.smics.apps.etst.domain.admin"> <class name="GroupFields"> <id name="id"> <generator class="native"/> </id> <property name="fieldsName" length='255'/> <property name="employeeNo" length='60'/> <property name="createDate" /> <property name="createdBy" length='60'/> </class> <class name="ReasonCode"> <id name="id"> <generator class="native"/> </id> <property name="codeType" length='20'/> <property name="smicTermCode" length='255'/> <property name="custCode" length='60'/> <property name="custTermCode" length='255'/> <property name="description" length='500'/> <property name="createDate" /> <property name="createdBy" length='60'/> </class> <class name="ResponserDept"> <id name="id"> <generator class="native"/> </id> <property name="orgId" length='255'/> <property name="deptName" length='255'/> <property name="secName" length='255'/> <property name="magrId" length='10'/> <property name="costCode" length='20'/> <property name="pieVerify" length='20'/> <property name="pieSite" length='20'/> <property name="createDate" /> <property name="createdBy" length='60'/> </class> <query name="findGroupByMember"><![CDATA[ from GroupFields g where g.employeeNo = ? ]]></query> <query name="findCccByMagrId"><![CDATA[ from ResponserDept g where g.magrId = ? ]]></query> <query name="findResponserDeptByOrgId"><![CDATA[ from ResponserDept g where g.orgId = ? ]]></query> <query name="findResDeptByDeptSec"><![CDATA[ from ResponserDept g where g.deptName = ? and g.secName = ? ]]></query> <query name="findResSecByDept"><![CDATA[ from ResponserDept g where g.deptName = ? ]]></query> <query name="findReasonCodeByCodeType"><![CDATA[ from ReasonCode r where r.codeType = ? ]]></query> </hibernate-mapping>
08-29
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值