<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框架
    主站蜘蛛池模板: 中美日韩在线网免费毛片视频| 亚洲情A成黄在线观看动漫软件 | 亚洲日本国产乱码va在线观看| 中文字幕一区二区免费| 美腿丝袜亚洲综合| 国产精品九九久久免费视频| 亚洲AV网站在线观看| 人成午夜免费大片在线观看| 亚洲乱码日产精品a级毛片久久| 无码人妻一区二区三区免费视频 | 在线永久免费观看黄网站| 亚洲精品无码专区久久| 四虎影院永久免费观看| 爱情岛论坛免费视频| 亚洲精品国产高清不卡在线| 中文字幕在线观看免费| 亚洲国产精品无码AAA片| 丁香花在线视频观看免费| 无码乱人伦一区二区亚洲一| 免费A级毛片无码专区| 亚洲同性男gay网站在线观看| 久久不见久久见中文字幕免费| 久久久久亚洲国产AV麻豆| 亚洲AV无码之日韩精品| 免费观看一区二区三区| 亚洲国产电影在线观看| 日韩免费视频播播| 中文字幕视频免费在线观看| 亚洲视频一区在线观看| 日本a级片免费看| 羞羞视频免费网站在线看| 亚洲免费一级视频| 四虎永久免费地址在线观看| 国产免费爽爽视频在线观看| 亚洲一区二区免费视频| 亚洲成?v人片天堂网无码| 久9这里精品免费视频| 亚洲欧美日韩综合俺去了| 国产午夜亚洲精品理论片不卡| 中文字幕在线免费| 怡红院亚洲红怡院在线观看|