Hibernate QBC查询的例子

//查找全部
        Criteria cr= session.createCriteria(Users.class);
        //添加各种条件
        //1 LIKE查询
        Criterion c1= Expression.like("name","t%");
        //2 等于 age=12
        Criterion c2 = Expression.eq("age", 12);
        //3 大于 age>12
        Criterion c3 = Expression.gt("age", 12);
        //4 不等于 age!=12
        Criterion c4 = Expression.not(Expression.eq("age", 12));
        //5 age为空
        Criterion c5 = Expression.isNull("age");
        //6 in语句
        Criterion c6 = Expression.in("name", new String[]{"tome","jack","jerry"});
        //7 between 语句
        Criterion c7 = Expression.between("age", 12, 15);
        //8  以t开头,长度为3的名字,并且忽略大小写
        Criterion c8 = Expression.like("name", "t_ _").ignoreCase();
        //添加查询条件并按age降序排列
        cr.add(c1).addOrder(Order.desc("age"));
        cr.add(c2);

方法二:将查询语句存入相应的配置文件中,这样可以在程序中调用

 

Xml代码
<query name="look">
        <![CDATA[
            from Users
        ]]>
    </query>
    <!-- 带参数的 -->
    <query name="lookName">
        <![CDATA[
            from Users p where p.name =:name
        ]]>
    </query>

 在程序中这样调用

Query query=session.getNamedQuery("lookName");
        query.setString("name","tom");
        List list=query.list();
        //List list=cr.list();
        for (Iterator iterator = list.iterator(); iterator.hasNext();) {
            Users element = (Users) iterator.next();
            System.out.println(element.getName());
        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值