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

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

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

    隨筆-21  評論-29  文章-0  trackbacks-0

    在Base類中加入以下代碼實現get方法

    package cn.itcast.hibernate;
    import java.util.Date;

    import org.hibernate.HibernateException;
    import org.hibernate.Session;
    import cn.itcast.hibernate.domain.User;
    import org.hibernate.Transaction;
    public class Base {

        
    public static void main(String[] args) {
            
            User user 
    = new User();
            user.setBirthday(
    new Date());
            user.setName(
    "name");
            addUser(user);    
            
            User u 
    = getUser(user.getId());
            System.out.println(
    "name:"+u.getName());
        }

        
         
    static User getUser(int id){
             Session s 
    = null ;
             
    try{
                 s 
    = HibernateUtil.getSession();
                 Class userClass 
    = User.class;
                 User user 
    = (User)s.get(User.class,id);
                 
    return user ;
             }
    finally {
                 
    if(s !=null)
                     s.close();
             }

         }

        
            
    static void addUser(User user){
                Session s 
    = null ;
                Transaction tx 
    = null ;
                
    try{
                    s 
    = HibernateUtil.getSession();
                    tx 
    = s.beginTransaction();
                    s.save(user);
                    tx.commit();
                }
    catch(HibernateException e){
                    
    if(tx !=null)
                        tx.rollback();
                    
    throw e ;
                }
    finally {
                    
    if(s !=null)
                        s.close();
                }

            }

            
    }

    對get方法參數User.class的理解:
    由于Session可以管理多個數據庫表所對應的多個實體對象。如果要查詢id為1的實體對象,Session.get方法需要知道去哪個數據庫表中查詢id為1的記錄,所以。除了給get方法傳遞所要查詢的實體對象的id值外,還必須給get方法傳遞實體對象的類型,get方法才能知道去哪個數據庫表中進行查詢。
    控制臺顯示結果:    name:name

    在配置文件hibernate.cfg.xml文件中加入
    <property name="show_sql">true</property> 
    可顯示所執行的sql語句

    load方法
    懶加載 并不馬上訪問數據庫 只有第一次應用時才訪問數據庫 load方法的返回對象永遠不可能為空

    package cn.itcast.hibernate;
    import java.util.Date;

    import org.hibernate.HibernateException;
    import org.hibernate.Session;
    import cn.itcast.hibernate.domain.User;
    import org.hibernate.Transaction;
    public class Base {

        
    public static void main(String[] args) {
            
            User user 
    = new User();
            user.setBirthday(
    new Date());
            user.setName(
    "name");
            addUser(user);    
            
            User u 
    = getUser(user.getId());
            System.out.println(
    "name:"+u.getName());
        }

        
         
    static User getUser(int id){
             Session s 
    = null ;
             
    try{
                 s 
    = HibernateUtil.getSession();
                 Class userClass 
    = User.class;
                 
    //User user = (User)s.get(User.class,id);
                 User user1 = (User)s.load(User.class,id);
                 System.out.println(
    "name:"+user1.getName());
                 System.out.println(user1.getClass().getName());
                 
    return user1 ;
             }
    finally {
                 
    if(s !=null)
                     s.close();
             }

         }

        
            
    static void addUser(User user){
                Session s 
    = null ;
                Transaction tx 
    = null ;
                
    try{
                    s 
    = HibernateUtil.getSession();
                    tx 
    = s.beginTransaction();
                    s.save(user);
                    tx.commit();
                }
    catch(HibernateException e){
                    
    if(tx !=null)
                        tx.rollback();
                    
    throw e ;
                }
    finally {
                    
    if(s !=null)
                        s.close();
                }

            }

            
    }


    在這里增加的打印user1類名的代碼,看到load方法所返回User子類的名稱。

    save與persist方法的區別:在沒有開啟事務的時候
    save方法會把數據插入到數據,之后又回滾,刪掉數據。而persist方法根本就不執行插入。

    總結Session的幾個主要方法:
      1 save,persist保存數據,persist在事務外不會產生insert語句;
      2.delete,刪除對象;
      3.update,更新對象,如果數據庫中沒有記錄,會出現異常;
      4.get,根據id查,會立刻訪問數據庫。
      5.load,根據id查(返回的是代理,不會立即訪問數據庫)
      6.saveOrUpdate,merge(根據id和version的值來確定是save或update),調用merge你的對象還是托管的。
      7.lock()把對象變成持久對象,但不會同步對象的狀態

    下午學習實體對象的三種狀態與saveOrUpdate方法。

    posted on 2009-05-04 11:10 特立獨行 閱讀(1005) 評論(0)  編輯  收藏 所屬分類: Hibernate框架
    主站蜘蛛池模板: 亚洲日本VA中文字幕久久道具| 亚洲国产精品无码专区在线观看| 亚洲另类古典武侠| 久久精品成人免费看| 久久久久亚洲AV成人网人人网站| 日韩免费在线中文字幕| jlzzjlzz亚洲乱熟在线播放| 羞羞漫画在线成人漫画阅读免费 | 亚洲丝袜美腿视频| 高清永久免费观看| 亚洲av无码不卡一区二区三区| 免费无码又爽又刺激网站直播| 亚洲AV成人精品网站在线播放| 一级毛片免费观看| 亚洲一区无码中文字幕乱码| 97人伦色伦成人免费视频| 亚洲av无码成人精品区一本二本| 国产免费69成人精品视频| 免费无码国产V片在线观看| 国产亚洲精品看片在线观看| 久久国产乱子伦精品免费不卡 | 成年人视频在线观看免费| 亚洲AV永久无码天堂影院| 亚洲成av人片在线观看天堂无码| 一级毛片免费不卡| 在线免费观看亚洲| 在线观看免费污视频| 一级毛片大全免费播放| 亚洲国产高清在线| 国产男女猛烈无遮挡免费视频网站 | 亚洲人成色77777在线观看大| 两性色午夜免费视频| 亚洲一区二区电影| 波多野结衣久久高清免费 | 日韩在线视频免费| 亚洲黄色片在线观看| 日本xxwwxxww在线视频免费| 中出五十路免费视频| 亚洲 日韩 色 图网站| 亚洲中文字幕在线观看| 1000部免费啪啪十八未年禁止观看 |