Hibernate的<query>标签使用

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); 
}

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值