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

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

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

    posts - 262,  comments - 221,  trackbacks - 0

    根據(jù)Informa的API說法,Informa提供了基于數(shù)據(jù)庫的持久化方式,這些持久化方法是通過Hibernate支持的。首先從Informa的源代碼包的build.xml開始追蹤。關(guān)于Informa的持久化,在Informa的zip包下有兩個(gè)文件和兩個(gè)目錄需要注意:

     A.build.xml:Ant腳本文件
     B.build.properties-template:Ant腳本文件需要用到的屬性文件模板
     C.config目錄:包含了hibernate.properties文件模板
     D.sql目錄:其下的schema目錄包含了hsqldb,mysql,postgres數(shù)據(jù)庫的ddl和屬性文件


    ★Informa的數(shù)據(jù)庫構(gòu)建過程

    在Informa的build.xml文件中,有3個(gè)target是和數(shù)據(jù)庫DDL相關(guān)的,它們分別是:
     A.hibernate.initdb:初始化數(shù)據(jù)庫連接
     B.hibernate.dbscheme.generate:根據(jù)用戶的指定生成對應(yīng)的ddl文件 
     C.hibernate.dbscheme:把hbm文件導(dǎo)出成為ddl文件

    這三個(gè)target的執(zhí)行順序是:
     initdb--->dbscheme.generate--->dbscheme 或者
     initdb--->dbscheme

    其中dbscheme是關(guān)鍵,它的主要工作包括:
     A.創(chuàng)建用于保存DDL輸出結(jié)果的scripts目錄
     B.定義一個(gè)名為schemaexport的Ant task,用于把hbm文件導(dǎo)出為ddl文件
     C.執(zhí)行schemaexport任務(wù),把classes目錄下的hbm文件export成DDL,并輸出到指定的位置
     D.輸出執(zhí)行結(jié)果信息


    為了盡量避免在Ant腳本中hardcode一些設(shè)置值,Ant腳本通過下列語句來引入屬性文件

      <!-- Read in (optional) external file with local property settings -->
      
    <property file="build.properties"/>

    build.properties文件是build.properties-template文件的runtime版,使用者去掉template后綴,然后根據(jù)需要修改,在運(yùn)行時(shí)Ant會(huì)自動(dòng)讀取該屬性文件的內(nèi)容,然后應(yīng)用到后面引用到這些屬性的地方。

    Ant中允許自定義任務(wù),這個(gè)功能通過taskdef標(biāo)記來完成

        <taskdef name="schemaexport"
                 classname
    ="org.hibernate.tool.hbm2ddl.SchemaExportTask">
          
    <classpath>
            
    <pathelement location="${build.classes}"/>
            
    <path refid="hibernate.classpath"/>
          
    </classpath>
        
    </taskdef>

    這個(gè)task通過Hibernate的內(nèi)置的SchemaExportTask來完成。我們要給他制定classpath路徑。定義完了任務(wù)后,就可以在下面使用它了

        <schemaexport properties="${hibernate.prop.file}"
                      quiet
    ="yes"
                      drop
    ="no"
                      text
    ="yes"
                      delimiter
    =";"
                      output
    ="${hibernate.schema.file}">
          
    <fileset refid="hibernate.mapping.files"/>
        
    </schemaexport>

    這個(gè)任務(wù)中,properties屬性指定了hibernate.properties文件,output指定了最終ddl的輸出位置。當(dāng)這個(gè)任務(wù)執(zhí)行時(shí),會(huì)根據(jù)hibernate.properties文件中指定的數(shù)據(jù)庫連接和方言,在classes目錄下搜索hbm文件,然后在scripts目錄下生成對應(yīng)的ddl文件。

    而對于
    hibernate.dbscheme.generate這個(gè)target,最主要的就是下面這個(gè)片段
        <!-- Hypersonic SQL: Replace hibernate settings with dialect specific -->
        
    <copy file="sql/schema/hsqldb/hsqldb-dialect.properties" 
              tofile
    ="${build.classes}/hibernate.properties" overwrite="true"/>

        
    <antcall target="hibernate.dbscheme">
          
    <param name="hibernate.schema.file" value="sql/schema/hsqldb/hsqldb-hibernate.ddl"/>
        
    </antcall>
        
        
    <!-- MySQL: Replace hibernate settings with dialect specific -->
        
    <copy file="sql/schema/mysql/mysql-dialect.properties" 
              tofile
    ="${build.classes}/hibernate.properties" overwrite="true"/>

        
    <antcall target="hibernate.dbscheme">
          
    <param name="hibernate.schema.file" value="sql/schema/mysql/mysql-hibernate.ddl"/>
        
    </antcall>
        
        
    <!-- PostgreSQL: Replace hibernate settings with dialect specific -->
        
    <copy file="sql/schema/postgres/postgres-dialect.properties" 
              tofile
    ="${build.classes}/hibernate.properties" overwrite="true"/>

        
    <antcall target="hibernate.dbscheme">
          
    <param name="hibernate.schema.file" value="sql/schema/postgres/postgres-hibernate.ddl"/>
        
    </antcall>

    它使用sql/scheme下的各個(gè)數(shù)據(jù)庫的配置文件來覆蓋hibernate.properties文件,然后通過antcall target="hibernate.dbscheme"這個(gè)task來調(diào)用上面講到的生成ddl過程。


    -------------------------------------------------------------
    生活就像打牌,不是要抓一手好牌,而是要盡力打好一手爛牌。
    posted on 2009-12-23 10:45 Paul Lin 閱讀(1343) 評論(0)  編輯  收藏

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


    網(wǎng)站導(dǎo)航:
     
    <2009年12月>
    293012345
    6789101112
    13141516171819
    20212223242526
    272829303112
    3456789

    常用鏈接

    留言簿(21)

    隨筆分類

    隨筆檔案

    BlogJava熱點(diǎn)博客

    好友博客

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲精品V欧洲精品V日韩精品 | 久久精品国产亚洲AV麻豆王友容| 免费在线精品视频| 免费人成年激情视频在线观看| 免费被黄网站在观看| 成人毛片免费观看| 在线观看永久免费视频网站| 日韩激情淫片免费看| 国产无遮挡色视频免费视频| 亚洲?V无码成人精品区日韩| 亚洲精品无码久久久久AV麻豆| 国产亚洲日韩一区二区三区| 国产成人A人亚洲精品无码| 亚洲大片在线观看| 亚洲沟沟美女亚洲沟沟| 99久久婷婷国产综合亚洲| 亚洲午夜无码久久久久软件| jzzijzzij在线观看亚洲熟妇| 日日狠狠久久偷偷色综合免费| sihu国产精品永久免费| 四虎影视无码永久免费| 久久精品无码专区免费青青| 免费A级毛片无码无遮挡内射| 日韩免费高清视频| 亚洲一区二区视频在线观看| 亚洲好看的理论片电影| 亚洲a∨无码男人的天堂| 国产成人高清亚洲一区久久| 国产精品玖玖美女张开腿让男人桶爽免费看 | 激情综合亚洲色婷婷五月APP| 亚洲中文字幕乱码一区| 美景之屋4在线未删减免费| 久久www免费人成精品香蕉| 99久久久国产精品免费牛牛四川| 一个人在线观看视频免费| 免费观看亚洲人成网站| 亚洲女同成av人片在线观看 | 亚洲乱码日产一区三区| 亚洲fuli在线观看| 杨幂最新免费特级毛片| 中文字幕视频免费|