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

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

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

    all gone

    all gone

    Eclipse下Hibernate入門


    1.開發(fā)環(huán)境
         Eclipse 3.2+MySQL 4.0.16+Hibernate3.0
        首先應(yīng)該安裝好Eclipse和MySQL,此外準(zhǔn)備好MySQL的JDBC Driver和Hibernate3.0,相關(guān)下載地址如下:
         Eclipse SDK:
            http://www.eclipse.org/downloads/index.php 
           MySQL及MySQL的JDBC Driver:
               http://www.mysql.org
           Hibernate:
              http://www.hibernate.org
           此外我還安裝了Eclipse的一個(gè)Hibernate插件:
         Hibernate synchronizer
               http://hibernatesynch.sourceforge.net


           Plugin Search:
             http://eclipse-plugins.2y.net/eclipse/search.jsp 

           Hibernate synchronizer插件的安裝和配置有問(wèn)題請(qǐng)直接Google。

         在工程中其實(shí)只用到了Hibernate synchronizer插件的一部分功能,Hibernate依賴的相關(guān)jar包最好還是手動(dòng)添加,因?yàn)樽铋_始用Hibernate synchronizer添加時(shí)總是發(fā)生錯(cuò)誤。
         將下載的Mysql driver和Hibernate包解壓縮,我們需要的只是里面相關(guān)的jar,在Eclipse中新建Mysql_Driver和Hibernate兩個(gè)user library,將mysql-connector-java-3.0.15-ga-bin.jar加入Mysql_Driver中,將hibernate3.jar,
    ,log4j-1.2.11.jar,antlr-2.7.5H3.jar,asm.jar,asm-attrs.jar,cglib-2.1.2.jar,commons-collections-2.1.1.jar,commons-logging-1.0.4.jar,dom4j-1.6.1.jar,ehcache-1.1.jar,jta.jar加入到Hibernate中。

    2.開始
    在Mysql中新建test數(shù)據(jù)庫(kù)(Mysql其實(shí)有個(gè)空的test數(shù)據(jù)庫(kù)),然后新建下面的Table

    create table user (
     id int(10) not null auto_increment primary key,
     name varchar(20) not null,
     password varchar(20) not null,
     email varchar(50),
     address varchar(100)
    )type=innodb;


    新建Java Project,將Mysql_Driver,Hibernate兩個(gè)user library添加到該工程的java build path中。

    新建與數(shù)據(jù)表對(duì)應(yīng)的POJO類:User和Contact

    /**
     *
     * 
     */
    package com.user;

    /**
     * @author lzy
     *
     */
    public class User{
        private Integer id;
        private String name;
        private String password;
        private Contact contact;
       

     /**
      * @return Returns the id.
      */
     public Integer getId() {
      return id;
     }
     /**
      * @param id The id to set.
      */
     public void setId(Integer id) {
      this.id = id;
     }
     /**
      * @return Returns the name.
      */
     public String getName() {
      return name;
     }
     /**
      * @param name The name to set.
      */
     public void setName(String name) {
      this.name = name;
     }
     /**
      * @return Returns the password.
      */
     public String getPassword() {
      return password;
     }
     /**
      * @param password The password to set.
      */
     public void setPassword(String password) {
      this.password = password;
     }
     /**
      * @return Returns the contact.
      */
     public Contact getContact() {
      return contact;
     }
     /**
      * @param contact The contact to set.
      */
     public void setContact(Contact contact) {
      this.contact = contact;
     }
       
       
    }
    /**
     *
     */
    package com.user;

    /**
     * @author lzy
     *
     */
    public class Contact {
     private String email;
        private String address;

     /**
      * @return Returns the address.
      */
     public String getAddress() {
      return address;
     }
     /**
      * @param address The address to set.
      */
     public void setAddress(String address) {
      this.address = address;
     }
     /**
      * @return Returns the email.
      */
     public String getEmail() {
      return email;
     }
     /**
      * @param email The email to set.
      */
     public void setEmail(String email) {
      this.email = email;
     }
    }

    之后可以用synchronizer插件生成Hibernate配置文件和映射文件(相關(guān)過(guò)程可以參考http://www.ideagrace.com/html/doc/2005/08/01/00315.html),不過(guò)映射文件必須稍作修改。

    hibernate.cfg.xml
    <?xml version="1.0" encoding="utf-8"?>
    <!DOCTYPE hibernate-configuration
        PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
        "

    <hibernate-configuration>
        <session-factory >

      <!-- local connection properties -->
      <property name="hibernate.connection.url">jdbc:mysql://localhost/test</property>
      <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
      <property name="hibernate.connection.username"></property>
      <property name="hibernate.connection.password"></property>
      <!-- property name="hibernate.connection.pool_size"></property -->

      <!-- dialect for MySQL -->
            <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

            <property name="hibernate.show_sql">True</property>
            <property name="hibernate.transaction.factory_class">org.hibernate.transaction.JDBCTransactionFactory</property>
         <mapping resource="User.hbm.xml"/>


        </session-factory>
    </hibernate-configuration>

    User.hbm.xml

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC
     "-//Hibernate/Hibernate Mapping DTD//EN"
     "

    <hibernate-mapping package="com.user">
     <class
      name="User"
      table="user"
     >
      <id
       name="Id"
       type="integer"
       column="id"
      >
       <generator class="native"/>
      </id>

      <property
       name="Name"
       column="name"
       type="string"
       not-null="true"
       length="20"
      />
      <property
       name="Password"
       column="password"
       type="string"
       not-null="true"
       length="20"
      />
      <component name="Contact" class="Contact">
       <property
       name="Email"
       column="email"
       type="string"
       not-null="false"
       length="50"
      />
      <property
       name="Address"
       column="address"
       type="string"
       not-null="false"
       length="100"
      />
      </component>
      


     </class> 
    </hibernate-mapping>

     

    3.測(cè)試
    添加一個(gè)測(cè)試類:HibernateTest

    package com.user;

    import java.util.List;
    import java.util.ListIterator;

    import org.hibernate.*;
    import org.hibernate.cfg.*;

    public class HibernateTest {
        public static void main(String[] args) throws HibernateException {
            SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
           
            //
            //testInsert(sessionFactory);
           
            //
            testQuery(sessionFactory);
           
             
            sessionFactory.close();
           
        }
        public static void testInsert( SessionFactory sessionFactory )throws HibernateException {
         
          Session session = sessionFactory.openSession();
            Transaction tx= session.beginTransaction();
            User user = new User();
            Contact contact=new Contact();
            contact.setEmail("email");
            contact.setAddress("address");
           
            user.setName("caterpillar");
            user.setPassword("password");
            user.setContact(contact);
           
            session.save(user);
            tx.commit();
            session.close();
            System.out.println("OK!");
       }
       
        public static void testQuery( SessionFactory sessionFactory )throws HibernateException {
         
         Session session = sessionFactory.openSession();
            Transaction tx= session.beginTransaction();
            User user = new User();
            Contact contact=new Contact();
                     
            Query query=session.createQuery("from User as user");
            //query.setCharacter(1, 'M');
            List names =query.list();
            for(ListIterator it=names.listIterator();it.hasNext();){
               user= (User)it.next();
               System.out.println("Id: " + user.getId());
                System.out.println("name: " + user.getName());
                System.out.println("password: " + user.getPassword());
                if(user.getContact()!=null){
                 
                 if(user.getContact().getEmail()!=null){
                  System.out.println("Email: " + user.getContact().getEmail());
                 }
                 if(user.getContact().getAddress()!=null){
                  System.out.println("Address: " + user.getContact().getAddress());
                   
                 }
                }
               
               
               
            }
             
          
            tx.commit();
            session.close();
         
        }
    }

     

      

     

    posted on 2005-12-10 12:50 all gone 閱讀(5041) 評(píng)論(3)  編輯  收藏 所屬分類: Java

    評(píng)論

    # re: Eclipse下Hibernate入門 2005-12-10 12:54 all gone

    總算完成了  回復(fù)  更多評(píng)論   

    # re: Eclipse下Hibernate入門 2006-05-31 14:51 cellen

    我做了下你說(shuō)的例子,在用HibernateSyn插件生成的那個(gè)hibernate.cfg.xml文件中,我要加上一段<mapping resource ="net/dxj/User.hbm.xml"/>然后在那個(gè),User.hbm.xml文件中ID的生成器上,更改成如此<generator class="native"/>,不過(guò),Constact.java我都沒(méi)有用上,我直接把email及address作為user的屬性的,如果不這樣做就報(bào)在user.java文件中找不到getter email方法的錯(cuò)誤!期待你的解決!msn:djpsunday@hotmail.com  回復(fù)  更多評(píng)論   

    # re: Eclipse下Hibernate入門 2006-05-31 15:10 cellen

    噢,不好意思,我照你貼出來(lái)的那個(gè)junit代碼重新配置一下,User.hbm.xml文件就成功了!^_^  回復(fù)  更多評(píng)論   

    主站蜘蛛池模板: 一级特级女人18毛片免费视频| 亚洲AV永久青草无码精品| 亚洲日日做天天做日日谢| 国产乱子精品免费视观看片| 亚洲精品~无码抽插| 永久免费不卡在线观看黄网站| 在线观看成人免费视频不卡| 亚洲永久中文字幕在线| 九九99热免费最新版| 亚洲精品~无码抽插| 777爽死你无码免费看一二区 | 一级毛片直播亚洲| 亚洲国产精品无码久久一区二区| 国产一级a毛一级a看免费人娇| 午夜免费福利网站| 久久亚洲精品无码av| 99爱免费观看视频在线| 国产成人毛片亚洲精品| 国产午夜不卡AV免费| 久久精品国产亚洲AV无码麻豆| caoporm超免费公开视频| 亚洲春色在线视频| h视频在线观看免费完整版| 久久亚洲国产中v天仙www| 69精品免费视频| 亚洲人成色77777在线观看| 亚洲欧洲一区二区三区| 亚在线观看免费视频入口| 国产成人A亚洲精V品无码 | 亚洲免费观看在线视频| 亚洲精品免费视频| 亚洲另类无码专区首页| 久久久久亚洲精品中文字幕 | 男女一进一出抽搐免费视频| 亚洲bt加勒比一区二区| 在线观看成人免费视频| ASS亚洲熟妇毛茸茸PICS| 91网站免费观看| 一区二区三区免费视频观看| 亚洲毛片基地日韩毛片基地 | 亚洲宅男永久在线|