今天在使用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&characterEncoding=UTF-8&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的錯誤,後來發現讀取出來的流是空的。。。。還有就是文件路徑最好還是使用絕對路徑,不讓很容易出現路徑錯誤。