<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    limq

    rainman
    隨筆 - 19, 文章 - 2, 評論 - 115, 引用 - 1
    數(shù)據(jù)加載中……

    條件查詢(Criteria Query)

    現(xiàn)在Hibernate也支持一種直觀的、可擴展的條件查詢API。目前為止,這個API還沒有更成熟的HQL查詢那么強大,也沒有那么多查詢能力。特別要指出,條件查詢也不支持投影(projection)或統(tǒng)計函數(shù)(aggregation)。

    12.1. 創(chuàng)建一個Criteria實例

    net.sf.hibernate.Criteria這個接口代表對一個特定的持久化類的查詢。Session是用來制造Criteria實例的工廠。

    Criteria crit = sess.createCriteria(Cat.class);
    crit.setMaxResults(50);
    List cats = crit.list();

    12.2. 縮小結果集范圍

    一個查詢條件(Criterion)是net.sf.hibernate.expression.Criterion接口的一個實例。類net.sf.hibernate.expression.Expression定義了獲得一些內(nèi)置的Criterion類型。

    List cats = sess.createCriteria(Cat.class)
    .add( Expression.like("name", "Fritz%") )
    .add( Expression.between("weight", minWeight, maxWeight) )
    .list();

    表達式(Expressions)可以按照邏輯分組.

    List cats = sess.createCriteria(Cat.class)
    .add( Expression.like("name", "Fritz%") )
    .add( Expression.or(
    Expression.eq( "age", new Integer(0) ),
    Expression.isNull("age")
    ) )
    .list();
    List cats = sess.createCriteria(Cat.class)
    .add( Expression.in( "name", new String[] { "Fritz", "Izi", "Pk" } ) )
    .add( Expression.disjunction()
    .add( Expression.isNull("age") )
    .add( Expression.eq("age", new Integer(0) ) )
    .add( Expression.eq("age", new Integer(1) ) )
    .add( Expression.eq("age", new Integer(2) ) )
    ) )
    .list();

    有很多預制的條件類型(Expression的子類)。有一個特別有用,可以讓你直接嵌入SQL。

    List cats = sess.createCriteria(Cat.class)
    .add( Expression.sql("lower($alias.name) like lower(?)", "Fritz%", Hibernate.STRING) )
    .list();

    其中的{alias}是一個占位符,它將會被所查詢實體的行別名所替代。(原文:The {alias} placeholder with be replaced by the row alias of the queried entity.)

    12.3. 對結果排序

    可以使用net.sf.hibernate.expression.Order對結果集排序.

    List cats = sess.createCriteria(Cat.class)
    .add( Expression.like("name", "F%")
    .addOrder( Order.asc("name") )
    .addOrder( Order.desc("age") )
    .setMaxResults(50)
    .list();

    12.4. 關聯(lián)(Associations)

    你可以在關聯(lián)之間使用createCriteria(),很容易地在存在關系的實體之間指定約束。

    List cats = sess.createCriteria(Cat.class)
    .add( Expression.like("name", "F%")
    .createCriteria("kittens")
    .add( Expression.like("name", "F%")
    .list();

    注意,第二個createCriteria()返回一個Criteria的新實例,指向kittens集合類的元素。

    下面的替代形式在特定情況下有用。

    List cats = sess.createCriteria(Cat.class)
    .createAlias("kittens", "kt")
    .createAlias("mate", "mt")
    .add( Expression.eqProperty("kt.name", "mt.name") )
    .list();

    createAlias())并不會創(chuàng)建一個Criteria的新實例。)

    請注意,前面兩個查詢中Cat實例所持有的kittens集合類并沒有通過criteria預先過濾!如果你希望只返回滿足條件的kittens,你必須使用returnMaps()。

    List cats = sess.createCriteria(Cat.class)
    .createCriteria("kittens", "kt")
    .add( Expression.eq("name", "F%") )
    .returnMaps()
    .list();
    Iterator iter = cats.iterator();
    while ( iter.hasNext() ) {
    Map map = (Map) iter.next();
    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);
    Cat kitten = (Cat) map.get("kt");
    }

    12.5. 動態(tài)關聯(lián)對象獲?。―ynamic association fetching)

    可以在運行時通過setFetchMode()來改變關聯(lián)對象自動獲取的策略。

    List cats = sess.createCriteria(Cat.class)
    .add( Expression.like("name", "Fritz%") )
    .setFetchMode("mate", FetchMode.EAGER)
    .setFetchMode("kittens", FetchMode.EAGER)
    .list();

    這個查詢會通過外連接(outer join)同時獲得 matekittens。

    12.6. 根據(jù)示例查詢(Example queries)

    net.sf.hibernate.expression.Example類允許你從指定的實例創(chuàng)造查詢條件。

    Cat cat = new Cat();
    cat.setSex('F');
    cat.setColor(Color.BLACK);
    List results = session.createCriteria(Cat.class)
    .add( Example.create(cat) )
    .list();

    版本屬性,表示符屬性和關聯(lián)都會被忽略。默認情況下,null值的屬性也被排除在外。

    You can adjust how the Example is applied. 你可以調(diào)整示例(Example)如何應用。

    Example example = Example.create(cat)
    .excludeZeroes() //exclude zero valued properties
    .excludeProperty("color") //exclude the property named "color"
    .ignoreCase() //perform case insensitive string comparisons
    .enableLike(); //use like for string comparisons
    List results = session.createCriteria(Cat.class)
    .add(example)
    .list();

    你甚至可以用示例對關聯(lián)對象建立criteria。

    List results = session.createCriteria(Cat.class)
    .add( Example.create(cat) )
    .createCriteria("mate")
    .add( Example.create( cat.getMate() ) )
    .list();

    posted on 2005-09-20 20:42 limq 閱讀(9262) 評論(1)  編輯  收藏

    評論

    # re: 條件查詢(Criteria Query)  回復  更多評論   

    請問兩個不關聯(lián)的表能構造一個Criteria嗎?
    比如:
    表A
    name
    descript

    表B:
    name
    address

    兩個表沒有關聯(lián),我想把name作為外連接條件,連接兩個表,要怎么樣構造呢,謝謝啦。!
    2006-05-18 20:06 | jackyhuang

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導航:
     
    主站蜘蛛池模板: 亚洲精品在线视频观看| 亚洲人成电影网站色| AV片在线观看免费| 青青久久精品国产免费看| 亚洲av日韩av无码| 欧洲精品免费一区二区三区| yellow视频免费看| 亚洲午夜成激人情在线影院| 免费人成在线观看网站视频| 亚洲视频免费一区| 亚洲精品视频免费| 亚洲日本人成中文字幕| 在线观看亚洲精品国产| 成人毛片18岁女人毛片免费看| 在线看片免费人成视频久网下载 | 免费看又黄又无码的网站| 亚洲综合色婷婷在线观看| 亚洲成av人影院| 免费大香伊蕉在人线国产| 久久精品无码专区免费东京热| 日韩少妇内射免费播放| 亚洲av午夜精品无码专区| 亚洲国产成人一区二区精品区 | 亚洲AV无码一区二区二三区软件| 性感美女视频在线观看免费精品 | 久久免费精彩视频| 羞羞漫画在线成人漫画阅读免费| 91亚洲精品麻豆| 亚洲精品无码鲁网中文电影| 日本一线a视频免费观看| 无码国产精品一区二区免费式直播 | 亚洲一区二区三区久久| 丁香五月亚洲综合深深爱| 午夜成人免费视频| 亚洲一级免费视频| a级毛片免费完整视频| 日韩毛片在线免费观看| 国产精品无码亚洲一区二区三区| 激情亚洲一区国产精品| 亚洲人成电影福利在线播放| 亚洲午夜国产精品无码老牛影视|