使用java代碼運行mybatis-generator-config.xml

今天在使用mybatis的generator代碼生成器時出現了一些小問題,在這裏記錄一下。

首先是generator的jar包,可以到http://mvnrepository.com/artifact/org.mybatis.generator/mybatis-generator-core

直接下載jar包或者用maven添加依賴都可以。

首先是關於XML文件的配置,如下所示,這其中最關鍵的問題就是這個驅動location,很容易出錯誤,最好就用絕對路徑來寫。還有就是表名一定實在數據庫中就存在的。url也是容易出錯的地方,要注意把&變成&還有就是mysql的高版本可能需要寫更多的參數如ssl和時區等。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
  PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
  "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
    <!--數據庫驅動-->
    <classPathEntry    location="C:\eeworkplace\mybatis-generator-core-1.3.5.jar"/>
    <context id="DB2Tables"    targetRuntime="MyBatis3Simple">
        <commentGenerator>
            <property name="suppressDate" value="true"/>
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!--數據庫鏈接地址賬號密碼-->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/mybatis_test?useUnicode=true&amp;characterEncoding=UTF-8&amp;useSSL=false" userId="root" password="zj1314">
        </jdbcConnection>
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>
        <!--生成Model類存放位置-->
        <javaModelGenerator targetPackage="model" targetProject="src\java">
            <property name="enableSubPackages" value="true"/>
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>
        <!--生成映射文件存放位置-->
        <sqlMapGenerator targetPackage="generator" targetProject="src\java">
            <property name="enableSubPackages" value="true"/>
        </sqlMapGenerator>
        <!--生成Dao類存放位置-->
        <javaClientGenerator type="XMLMAPPER" targetPackage="dao" targetProject="src\java">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>
        <!--生成對應表及類名-->
        <table tableName="user_pri" domainObjectName="Pri" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
    </context>
</generatorConfiguration>

然後就是執行xml文件的java代碼

http://www.mybatis.org/generator/running/runningWithJava.html上已經明確給出了使用xml配置java執行時的方法。

List<String> warnings = new ArrayList<String>();
   boolean overwrite = true;
   File configFile = new File("generatorConfig.xml");
   ConfigurationParser cp = new ConfigurationParser(warnings);
   Configuration config = cp.parseConfiguration(configFile);
   DefaultShellCallback callback = new DefaultShellCallback(overwrite);
   MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
   myBatisGenerator.generate(null);

我從書上看到的是用inputstram來接收,那樣總是會報Exception in thread "main" java.net.MalformedURLException的錯誤,後來發現讀取出來的流是空的。。。。還有就是文件路徑最好還是使用絕對路徑,不讓很容易出現路徑錯誤。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章