国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

mybatis入門基礎(九)----逆向工程

2019-11-15 00:54:01
字體:
來源:轉載
供稿:網友
mybatis入門基礎(九)----逆向工程一、什么是逆向工程  

mybaits需要程序員自己編寫sql語句,mybatis官方提供逆向工程可以針對單表自動生成mybatis執行所需要的代碼(mapper.java,mapper.xml、po..)

實際開發中,常用的逆向工程方式:由數據庫的表生成java代碼。

二、下載逆向工程

  去官網下載逆向工程,截至今天最新版本是1.3.3. 官方逆向工程文檔

我所用的是1.3.2版本的,下載地址: mybatis_generator所用jar包.zip

mybatis學習資料(中英文文檔,參數常見配置等).rar

三、使用方法

1.生成代碼配置文件

generatorConfig.xml的配置

 1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE generatorConfiguration 3   PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" 4   "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> 5  6 <generatorConfiguration> 7     <context id="testTables" targetRuntime="MyBatis3"> 8         <commentGenerator> 9             <!-- 是否去除自動生成的注釋 true:是 : false:否 -->10             <PRoperty name="suppressAllComments" value="true" />11         </commentGenerator>12         <!--數據庫連接的信息:驅動類、連接地址、用戶名、密碼,這里配置的是MySQL的,當然也可以配置Oracle等數據庫 -->13         <jdbcConnection driverClass="com.mysql.jdbc.Driver"14             connectionURL="jdbc:mysql://localhost:3306/mybatis" userId="root"15             passWord="root">16         </jdbcConnection>17 18         <!-- 默認false,把JDBC DECIMAL 和 NUMERIC 類型解析為 Integer,為 true時把JDBC DECIMAL 19             和 NUMERIC 類型解析為java.math.BigDecimal -->20         <javaTypeResolver>21             <property name="forceBigDecimals" value="false" />22         </javaTypeResolver>23 24         <!-- targetProject:生成PO類的位置 -->25         <javaModelGenerator targetPackage="com.mybatis.entity"26             targetProject="./src">27             <!-- enableSubPackages:是否讓schema作為包的后綴 -->28             <property name="enableSubPackages" value="false" />29             <!-- 從數據庫返回的值被清理前后的空格 -->30             <property name="trimStrings" value="true" />31         </javaModelGenerator>32         <!-- targetProject:mapper映射文件生成的位置 -->33         <sqlMapGenerator targetPackage="com.mybatis.mapper"34             targetProject="./src">35             <!-- enableSubPackages:是否讓schema作為包的后綴 -->36             <property name="enableSubPackages" value="false" />37         </sqlMapGenerator>38         <!-- targetPackage:mapper接口生成的位置 -->39         <javaClientGenerator type="XMLMAPPER"40             targetPackage="com.mybatis.mapper" targetProject="./src">41             <!-- enableSubPackages:是否讓schema作為包的后綴 -->42             <property name="enableSubPackages" value="false" />43         </javaClientGenerator>44         <!-- 指定數據庫表 -->45         <table tableName="items"></table>46         <table tableName="orders"></table>47         <table tableName="orderdetail"></table>48         <table tableName="t_user"></table>49     </context>50 </generatorConfiguration>

2.執行生成程序

GeneratorSqlmap.java的代碼:

 1 import java.io.File; 2 import java.util.ArrayList; 3 import java.util.List; 4  5 import org.mybatis.generator.api.MyBatisGenerator; 6 import org.mybatis.generator.config.Configuration; 7 import org.mybatis.generator.config.xml.ConfigurationParser; 8 import org.mybatis.generator.internal.DefaultShellCallback; 9 10 public class GeneratorSqlmap {11 12     public void generator() throws Exception{13 14         List<String> warnings = new ArrayList<String>();15         boolean overwrite = true;16         //指定 逆向工程配置文件17         File configFile = new File("generatorConfig.xml"); 18         ConfigurationParser cp = new ConfigurationParser(warnings);19         Configuration config = cp.parseConfiguration(configFile);20         DefaultShellCallback callback = new DefaultShellCallback(overwrite);21         MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config,22                 callback, warnings);23         myBatisGenerator.generate(null);24 25     } 26     public static void main(String[] args) throws Exception {27         try {28             GeneratorSqlmap generatorSqlmap = new GeneratorSqlmap();29             generatorSqlmap.generator();30         } catch (Exception e) {31             e.printStackTrace();32         }33         34     }35 36 }

上面這段代碼在官方文檔中的代碼,里面支持好多語言的,大家可以去官方看看。下面這張圖是從官方截取的

配置好后,直接運行代碼就會在配置的對應目錄生成對應的實體和mapper以及mapper.xml文件。(類似hibernate的實體映射),當然除了這種方法生成,還可以下載mybatis_generator插件生成。

執行完畢后,刷新項目,就可以看到生成的對應文件。

3.逆向工程注意事項

  mapper.xml文件已存在時,如果進行重新生成則mapper.xml文件內容不被覆蓋而是進行內容增加,結果會導致mybatis解析失敗。

  解決辦法:刪除原來的已經生成的mapper.xml文件重新生成。

  mybais自動生成的實體entity以及mapper.java文件不是內容追加而是直接覆蓋沒有問題。

4.工程目錄


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 梅河口市| 东辽县| 清镇市| 延川县| 青河县| 逊克县| 湖口县| 蒲江县| 栖霞市| 精河县| 吉林省| 铜鼓县| 谢通门县| 利辛县| 南昌市| 沙湾县| 平阴县| 双辽市| 六盘水市| 合肥市| 锦屏县| 曲沃县| 通江县| 清水河县| 黑水县| 香港 | 泉州市| 会泽县| 苍山县| 大冶市| 光山县| 同心县| 江口县| 贵阳市| 玛沁县| 临朐县| 娄烦县| 甘泉县| 皮山县| 黄浦区| 同仁县|