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

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

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

    posts - 30,  comments - 85,  trackbacks - 0
    JDO 的使用和集成
         這里不想討論JDO和JPA的區別,也不討論JDO的規范,單只是從JDO的使用和與應用的集成角度來概述。

    1. 下載JDO規范的實現開源包。目前主流的JDO實現有:
    *.TJDO http://tjdo.sf.net
    *.Speedo http://speedo.objectweb.org
    *.JORM http://jorm.objectweb.org
    *.XORM http://xorm.sourceforge.net
    *.JPOX http://jpox.sourceforge.net
    *.OJB http://db.apache.org/ojb/
    *.DataNucleus http://www.datanucleus.org/
     
    2. 這里選擇DataNucleus為JDO的實現,因為個人認為datanucleus大有一統O/R Mapping天下的架勢。前端支持JDO/JPA規范,后面能接多種數據存儲平臺(RDBMS, ODBMS, Map-based, Web-based, documents, etc) . 并且直接可與bigtable、hbase等分布式數據庫集成。實在強大。
         * 下載DataNucleus程序包
         * 下載DataNucleus在eclipse下的擴展插件

    3. 如果使用dataNucleus連接DBMS數據庫(Mysql)需要加入以下幾個jar包:
         datanucleus-enhancer-3.0.0-m4.jar   jdo-api-3.1-SNAPSHOT-20110319.jar  datanucleus-api-jdo-3.0.0-m4.jar  datanucleus-jdo-query-3.0.0-m2.jar    asm.jar
         mysql-connector-java-5.0.4-bin.jar  datanucleus-cache-3.0.0-m2.jar    datanucleus-management-1.0.2.jar datanucleus-core-3.0.0-m4.jar     datanucleus-rdbms-3.0.0-m4.jar

    4. 創建一個entity class 并配置映射文件 如下:
         entity class :
    @PersistenceCapable
    public class Person {     
           @PrimaryKey
           private String name ;
           private int age ;
           private String mail ;
         .......
    }
       mapping xml
    <jdo>
        <package name="com.jdo.data.nucleus.model">
            <class name="Person">
                <field name="name" persistence-modifier="persistent">
                     <column length="100" />
                </field>
                <field name="age" persistence-modifier="persistent"/>
                <field name="mail" persistence-modifier="persistent"/>
            </class>
        </package>
    </jdo>

    5.創建JDO操作類:
                 Map<String,String> JDOConfig = new HashMap<String,String>();
                JDOConfig.put( "javax.jdo.PersistenceManagerFactoryClass" ,"org.datanucleus.api.jdo.JDOPersistenceManagerFactory" );
               
                JDOConfig.put("javax.jdo.option.ConnectionURL", "jdbc:mysql://localhost/acegi" );
                JDOConfig.put( "javax.jdo.option.ConnectionDriverName" , "com.mysql.jdbc.Driver" );
                JDOConfig.put( "javax.jdo.option.ConnectionUserName" , "root");
                JDOConfig.put( "javax.jdo.option.ConnectionPassword" , "root");
                JDOConfig.put( "javax.jdo.option.NontransactionalRead" , "true");
                JDOConfig.put( "javax.jdo.option.NontransactionalWrite" , "true");
                JDOConfig.put( "datanucleus.autoCreateSchema" , "true" );
               
                PersistenceManagerFactory pmf = JDOHelper.getPersistenceManagerFactory(JDOConfig);
                PersistenceManager pm = pmf.getPersistenceManager();
                Person person = null;
                System. out.println("Insert iterm into DB. " );
                 //insert
                person = new Person("wenhao" ,123,"wenhao@gmail.com");
                pm.makePersistent(person);
                 //select
                 getPersonsFromDB(pm);
                 //update
                person.setMail( "wenhao@sina.com.cn");
                pm.close();
               
                person.setAge(1000);
                System. out.println("instance level : " + person.getAge());
               
                pmf = JDOHelper. getPersistenceManagerFactory(JDOConfig);
                pm = pmf.getPersistenceManager();
                List<Person> updatePersons = getPersonsFromDB(pm);
                 if(updatePersons != null && updatePersons.size() > 0) {
                       for(Person updatePerson : updatePersons)
                             //delete
                            pm.deletePersistent(updatePerson);
                      System. out.println("Delete iterms from DB." );
                }
                pm.close();
                //select
                Query q = pm.newQuery( "SELECT FROM " + Person.class.getName() + " WHERE name == 'wenhao'" );
                List<Person> updatePersons = (List)q.execute();

    6. 運行JDO操作類,這時直接運行會報如下的錯誤:
    This means that it either hasnt been enhanced, or that the enhanced version of the file is not in the CLASSPATH (or is hidden by an unenhanced version), or the Meta-Data/annotations for the class are not found
         這個錯誤的是因為沒有對Entity class進行jdo的enhance來增強entity的二進制代碼。故需要在project上增加datanucleus支持。并運行enhancer tool來enhance entity。運行后可通過反編譯工具來查看transform后的class。可發現多了一些屬性和方法。這些都是對JDO entity的擴展。

    7.正常運行
         會發現在person.setMail( "wenhao@sina.com.cn" );會更改到底層的數據庫中,而person.setAge(1000);并不會更改數據庫字段。其實很容易理解。類似hibernate的entity的幾個狀態,自由態·持久態·游離態。 當pm.close();后person處于自由態,修改的屬性只有在instance內部有效。而在pm cloase或transaction.commit之前時,entity仍處理持久化狀態,直接修改屬性,會持久化到底層數據庫中。
        
    8.JDO對象的多對多關系實現。多對多和hibernate的配置類似,主要還是在配置文件上做一些配置。配置文件如下:
    Person.jdo:
    <jdo>
        <package name="com.jdo.data.nucleus.model">
            <class name="Person">
                <field name="name" persistence-modifier="persistent">
                      <column length="100" jdbc-type="VARCHAR" />
                </field>
                <field name="age" persistence-modifier="persistent"/>
                <field name="mail" persistence-modifier="persistent"/>
                <field name="roles" persistence-modifier="persistent" table="PERSON_RULE">
                      <collection element-type="com.jdo.data.nucleus.model.Role" />
                      <join>
                        <column name="name" />
                    </join>
                    <element>
                        <column name="roleName" />
                    </element>
                </field>

            </class>
        </package>
    </jdo>
    Role.jdo:
    <jdo>
        <package name="com.jdo.data.nucleus.model">
            <class name="Role">
                <field name="roleName" persistence-modifier="persistent">
                      <column length="100" jdbc-type="VARCHAR" />
                </field>
                <field name="roleDesc" persistence-modifier="persistent"/>
                <field name="persons" persistence-modifier="persistent" table="PERSON_RULE">
                      <collection element-type="com.jdo.data.nucleus.model.Person" />
                      <join>
                        <column name="roleName" />
                    </join>
                    <element>
                        <column name="name" />
                    </element>
                </field>

            </class>
        </package>
    </jdo>
    Person.java:
    @PersistenceCapable
    public class Person {
           @PrimaryKey
           private String name ;
           private int age ;
           private String mail ;     
           @Element
           private Set<Role> roles ;
    }
    Role.java:
    @PersistenceCapable
    public class Role {
           @PrimaryKey
           private String roleName ;
           private String roleDesc ;
           @Element
           private Set<Person> persons ;
    }
    以上配置可實現多對多的關系。并能夠進行關聯查詢。

    posted on 2011-05-15 17:19 安文豪 閱讀(2827) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     

    <2011年5月>
    24252627282930
    1234567
    891011121314
    15161718192021
    22232425262728
    2930311234

    常用鏈接

    留言簿(6)

    隨筆檔案(28)

    文章分類(3)

    文章檔案(4)

    最新隨筆

    搜索

    •  

    積分與排名

    • 積分 - 86469
    • 排名 - 666

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 免费看男人j放进女人j免费看| 成人无码区免费A片视频WWW| 亚洲免费在线播放| 97人伦色伦成人免费视频 | 亚洲中文字幕无码av永久| 亚洲а∨天堂久久精品| 99精品视频在线视频免费观看 | 亚洲黄色免费网站| 国产成人高清亚洲一区91 | 深夜免费在线视频| 亚洲欧洲自拍拍偷综合| 亚洲日韩国产一区二区三区| 91精品免费久久久久久久久| 日韩在线一区二区三区免费视频 | 成人免费在线视频| 成在人线av无码免费高潮喷水| 亚洲永久在线观看| 亚洲AV无码久久精品成人| 国产精品二区三区免费播放心| 麻豆成人久久精品二区三区免费| 亚洲a∨无码精品色午夜| 亚洲成a人片在线观看中文!!!| 亚洲精品无码久久毛片| 女人18毛片水真多免费播放| 日本在线免费观看| 国产成人高清精品免费观看| 亚洲精品无码aⅴ中文字幕蜜桃| 亚洲天堂男人天堂| 亚洲精品无码久久千人斩| 国产小视频在线观看免费| 免费H网站在线观看的| 免费视频精品一区二区三区 | 日韩大片免费观看视频播放| 亚洲AV无码专区在线亚| 日韩亚洲Av人人夜夜澡人人爽| 亚洲欧洲日本在线| 免费在线观看一级毛片| 国产又粗又长又硬免费视频| 毛片免费视频在线观看| 91热久久免费精品99| 暖暖在线视频免费视频|