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

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

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

    空間站

    北極心空

      BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
      15 Posts :: 393 Stories :: 160 Comments :: 0 Trackbacks
    Criteria Query是Hibernate提供的將SQL語句對象化表示的一種方法。當我們使用JDBC方式查詢數(shù)據(jù)時會這樣寫: 
    select NAME FROM EMPLOYEE where ID = '001' 

    使用Hibernate的Criteria Query方式查詢時,就可以使用我們已經(jīng)習慣了的面向?qū)ο蟮姆绞健H缦拢?/font> 

     
    程序代碼 程序代碼
    import net.sf.hibernate.Criteria; 
    import net.sf.hibernate.expression.Expression; 
    ... 

    Criteria criteria = session.createCriteria(Employee.class); 
    criteria.add(Expression.eq("id", "001")); 
    ArrayList list = criteria.list(); 
    ... 


      其中Expression對象是where條件的封裝,提供了查詢限定機制,現(xiàn)在介紹一下他的具體使用:
     
     Expression的方法描述 
    Expression.eq:對應SQL條件中的"field = value"。如:Expression.eq("id","001") 
    Expression.allEq:參數(shù)為一個Map對象,其中包含了多個屬性和值對應關系。相當于多個Expression.eq關系,多個條件。如: 
    程序代碼 程序代碼
    map.put("id", "001"); 
    map.put("name", "hiswing"); 
    Expression.allEq(map); 


    Expression.gt:對應SQL條件中的"field > value "。如:Expression.gt("salary", new Integer(5000)) 
    Expression.ge:對應SQL條件中的"field >= value"。 
    Expression.lt:對應SQL條件中的"field < value"。 
    Expression.le:對應SQL條件中的"field <= value"。 
    Expression.between:對應SQL條件中的"between"。 
    Expression.like:對應SQL條件中的"field like value"。 
    Expression.in:對應SQL條件中的"field in …"。 
    Expression.eqProperty:用于比較兩個屬性之間的值,對應SQL條件中的"field = field"。如:Expression.eqProperty("Employee.id", "Group.eid"); 
    Expression.gtProperty:用于比較兩個屬性之間的值,對應SQL條件中的"field > field"。 
    Expression.geProperty:用于比較兩個屬性之間的值,對應SQL條件中的"field >= field"。 
    Expression.ltProperty:用于比較兩個屬性之間的值,對應SQL條件中的"field < field"。 
    Expression.leProperty:用于比較兩個屬性之間的值,對應SQL條件中的"field <= field"。 
    Expression.and:and關系組合。
     
    如: 
    Expression.and( 
      Expression.eq("name","hiswing"), 
      Expression.eq("sex", new Integer(1)) 


    Expression.or:or關系組合。(使用方法同Expression.and) 
    Expression.sql:我們可以通過這個方法直接通過SQL語句限定查詢條件。
     

      注:在使用Criteria時,Expression中的KEY為POJO中的屬性。如Expression.eq("id", "001")中的id為Employee對象中id這個屬性,注意大小寫
     
     
     
    ****************************************************************************************
     有很多預制的條件類型(Expression的子類)。有一個特別有用,可以讓你直接嵌入SQL。 

    List cats = sess.createCriteria(Cat.class)
        .add( Expression.sql("lower($alias.name) like lower(?)", "Fritz%", Hibernate.STRING) )
        .list();
    其中的{alias}是一個占位符,它將會被所查詢實體的行別名所替代.

    ************************************************************

     

     
    posted on 2008-06-24 18:21 蘆葦 閱讀(2390) 評論(0)  編輯  收藏 所屬分類: Hibernate
    主站蜘蛛池模板: 亚洲午夜福利在线观看| 国产成人高清精品免费鸭子| 亚洲免费黄色网址| 日韩伦理片电影在线免费观看| 一个人看的www视频免费在线观看 一个人看的免费观看日本视频www | www.黄色免费网站| 国产精品久久亚洲一区二区| 亚洲AV人人澡人人爽人人夜夜| 国产免费毛不卡片| 丁香花在线观看免费观看图片| 亚洲成人午夜电影| 久久久久亚洲AV综合波多野结衣| 99热这里只有精品免费播放| 小说区亚洲自拍另类| 99亚洲精品高清一二区| 四虎影视免费永久在线观看 | 久久99国产综合精品免费| 精品国产亚洲第一区二区三区| 亚洲第一视频网站| 免费一级肉体全黄毛片| 91精品免费高清在线| 一级毛片免费观看不收费| 激情亚洲一区国产精品| 国产亚洲AV无码AV男人的天堂| 国产精品酒店视频免费看| 182tv免费观看在线视频| 一级特级女人18毛片免费视频 | 91av免费观看| aaa毛片免费观看| 亚洲av片在线观看| 亚洲国产成人精品电影| 国产亚洲一区二区在线观看| 国产免费av片在线播放| 99久久精品日本一区二区免费| 两个人看的www高清免费视频| 相泽南亚洲一区二区在线播放| 国产精品亚洲四区在线观看| 久久亚洲成a人片| 国产亚洲人成A在线V网站| 免费人成年激情视频在线观看| 美女视频黄是免费的网址|