<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区 | 国产一区二区三区无码免费| 亚洲精品二三区伊人久久| www视频免费看| 亚洲大尺码专区影院| 午夜性色一区二区三区免费不卡视频| 亚洲视频免费观看| 美女视频黄免费亚洲| 久久夜色精品国产噜噜亚洲a| 久久精品网站免费观看| 亚洲gay片在线gv网站| 免费国产一级特黄久久| 九九免费精品视频在这里| 国产精品亚洲A∨天堂不卡| 无码人妻AV免费一区二区三区| 亚洲高清资源在线观看| 妞干网在线免费观看| 免费播放美女一级毛片| 亚洲自偷自偷图片| 久久精品国产免费观看| 亚洲性色AV日韩在线观看| 亚洲伦乱亚洲h视频| 免费精品一区二区三区第35| 亚洲女人初试黑人巨高清| 国产高清免费观看| 免费看无码特级毛片| 亚洲伊人久久大香线蕉结合| 免费少妇a级毛片人成网| 最近免费中文字幕MV在线视频3| 亚洲综合久久久久久中文字幕| 成人免费一区二区三区在线观看| 男人扒开添女人下部免费视频| 午夜影视日本亚洲欧洲精品一区| 毛片免费视频播放| WWW免费视频在线观看播放| 亚洲性69影院在线观看| 亚洲精品在线视频| 久久精品网站免费观看| 国产免费无码一区二区| 亚洲精品V天堂中文字幕| 亚洲国产成人一区二区精品区|