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

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

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

    空間站

    北極心空

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

    使用Hibernate的Criteria Query方式查詢時,就可以使用我們已經習慣了的面向對象的方式。如下:
     

     
    程序代碼 程序代碼
    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條件的封裝,提供了查詢限定機制,現在介紹一下他的具體使用:
     
     Expression的方法描述 
    Expression.eq:對應SQL條件中的"field = value"。如:Expression.eq("id","001") 
    Expression.allEq:參數為一個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
    主站蜘蛛池模板: 亚洲av无码无线在线观看| 国产精品高清视亚洲精品| 精品无码一级毛片免费视频观看 | 最近中文字幕无吗免费高清| 亚洲福利视频网站| 四虎1515hh永久久免费| 91午夜精品亚洲一区二区三区| 59pao成国产成视频永久免费| 亚洲精品国产成人| 国产一卡2卡3卡4卡无卡免费视频| 亚洲av专区无码观看精品天堂| 最新中文字幕免费视频| 色偷偷亚洲男人天堂| 亚洲AV蜜桃永久无码精品| 91在线老王精品免费播放| 777亚洲精品乱码久久久久久| 91精品国产免费| 日本亚洲精品色婷婷在线影院 | 青草草色A免费观看在线| 亚洲人成网男女大片在线播放| 大学生高清一级毛片免费| 免费看美女午夜大片| 久久久亚洲精品视频| 一级女人18毛片免费| 看Aⅴ免费毛片手机播放| 亚洲精品亚洲人成在线观看| free哆啪啪免费永久| 亚洲成av人无码亚洲成av人| 亚洲中文字幕无码不卡电影 | 国产激情免费视频在线观看| 亚洲国产成人无码av在线播放| 成年美女黄网站18禁免费| gogo免费在线观看| 亚洲国产品综合人成综合网站| 免费人成视频在线观看视频| 嫩草成人永久免费观看| 亚洲国产成人精品无码区二本| 亚洲精品乱码久久久久久久久久久久| 日本免费人成在线网站| 日韩在线视频播放免费视频完整版| 久久伊人久久亚洲综合|