<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框架
    主站蜘蛛池模板: 亚洲欧洲在线观看| 亚洲av永久无码精品网站 | 亚洲av永久无码一区二区三区| 亚洲av无码一区二区乱子伦as| 亚洲va久久久噜噜噜久久男同| 精品亚洲成a人片在线观看少妇| 亚洲另类春色校园小说| 日韩免费人妻AV无码专区蜜桃| 啦啦啦高清视频在线观看免费| 亚洲国产婷婷综合在线精品| 无码一区二区三区亚洲人妻| 国产午夜免费福利红片| 黄色片网站在线免费观看| 亚洲AV无码一区二区三区在线观看| 亚洲成AV人在线观看天堂无码| 亚洲国产日韩视频观看| 精品国产精品久久一区免费式| 亚洲综合无码精品一区二区三区| 亚洲一区二区三区高清不卡| 两性刺激生活片免费视频| 亚洲乱码中文字幕在线| 国产又黄又爽又刺激的免费网址| 久久久无码精品亚洲日韩蜜桃| 国产成人人综合亚洲欧美丁香花| 暖暖免费在线中文日本| 老色鬼久久亚洲AV综合| 在线看片无码永久免费视频| 福利片免费一区二区三区| 区三区激情福利综合中文字幕在线一区亚洲视频1 | 一级毛片**不卡免费播| 亚洲精品自产拍在线观看动漫 | aa午夜免费剧场| 国产亚洲精品a在线观看app| 在线看片免费人成视久网| 亚洲首页国产精品丝袜| 日本媚薬痉挛在线观看免费| 91福利免费网站在线观看| 亚洲精品视频免费看| 日本中文一区二区三区亚洲| 久久国产免费一区二区三区| 亚洲乱码av中文一区二区|