<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 特立獨行 閱讀(1006) 評論(0)  編輯  收藏 所屬分類: Hibernate框架
    主站蜘蛛池模板: 亚洲免费在线观看视频| 国产AV无码专区亚洲AV男同| 久久精品国产亚洲αv忘忧草| 又大又硬又爽又粗又快的视频免费| 久久亚洲精品成人777大小说| 免费人成黄页在线观看日本| 久久精品国产亚洲av成人| 无码成A毛片免费| 亚洲小说区图片区| 国产美女在线精品免费观看| 久久久久亚洲精品无码网址色欲| 在线观看亚洲免费| 污污视频网站免费观看| 亚洲精品字幕在线观看| 免费观看美女用震蛋喷水的视频| 亚洲香蕉在线观看| 全黄a免费一级毛片人人爱| 国产va免费精品| 亚洲国产精品自在在线观看| 免费看男女下面日出水来| 亚洲av无一区二区三区| 亚洲午夜成人精品电影在线观看| 永久免费av无码入口国语片| 亚洲男人天堂影院| 四虎永久精品免费观看| 成年女人A毛片免费视频| 少妇中文字幕乱码亚洲影视| 国产美女在线精品免费观看| 又长又大又粗又硬3p免费视频| 久久久久无码精品亚洲日韩 | 国产精品视频白浆免费视频| 亚洲国产成人久久精品app | 久久久久久久综合日本亚洲| 50岁老女人的毛片免费观看| 亚洲AV第一成肉网| 亚洲va久久久噜噜噜久久男同 | 黄色免费网站网址| 一区二区三区免费在线视频 | 久久久久高潮毛片免费全部播放 | 精品久久久久国产免费| 久青草视频在线观看免费|