日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

基于Java代碼配置MyBatis Generator

瀏覽:177日期:2022-08-30 18:32:58

使用MyBatis Generator生成器時,有時候沒辦法使用xml形式的配置文件,比如將Maven項目設置成pom打包方式(<packaging>pom</packaging>)!由于Maven的工作機制對于打包方式為pom的項目是不會輸出jar包或war包和resources內容,所以放在resources目錄下或放在源碼目錄下的xml文件就沒法讀取了,就算你在pom.xml文件中明確有如下配置也沒有用的:

<build> <resources> <resource><directory>src/main/java</directory><includes> <include>**/*.properties</include> <include>**/*.yml</include> <include>**/*.xml</include></includes> </resource> <resource><directory>src/main/resources</directory><includes> <include>**/*.properties</include> <include>**/*.yml</include> <include>**/*.xml</include></includes> </resource> </resources> </build>

這個時候就會用到純Java代碼的MyBatis Generator配置,直接貼配置代碼:

import org.mybatis.generator.config.*;/** * 基于Java代碼的MBG配置 * Maven打包方式為POM的項目或模塊(<packaging>pom</packaging>),resources目錄的內容不會輸出到類路徑下,所以可以選擇直接使用Java代碼配置! * * @author 707669522@qq.com * @since 2020-06-13 */public class GeneratorConfig { public static Configuration getGeneratorConfig() { Context context = new Context(ModelType.CONDITIONAL); context.setId('simple'); context.setTargetRuntime('MyBatis3Simple'); /*添加屬性*/ context.addProperty('javaFileEncoding', 'UTF-8'); /*插件配置,這個是我自己的插件,沒有自定義插件的同學可以不配這一節,刪除即可*/ PluginConfiguration pluginConfig = new PluginConfiguration(); pluginConfig.setConfigurationType('com.xgclassroom.generator.GeneratorPlugin'); context.addPluginConfiguration(pluginConfig); /*注釋生成器配置*/ CommentGeneratorConfiguration commentGeneratorConfig = new CommentGeneratorConfiguration(); commentGeneratorConfig.addProperty('suppressAllComments', 'true'); context.setCommentGeneratorConfiguration(commentGeneratorConfig); /*JDBC連接信息配置*/ JDBCConnectionConfiguration jdbcConnectionConfig = new JDBCConnectionConfiguration(); jdbcConnectionConfig.setDriverClass('com.mysql.cj.jdbc.Driver'); //注意代碼配置中JDBC連接字符串中的參數分隔符不需要再像xml配置文件中那樣使用轉義符 jdbcConnectionConfig.setConnectionURL('jdbc:mysql://localhost:3306/permission_center?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false'); jdbcConnectionConfig.setUserId('xurm'); jdbcConnectionConfig.setPassword('1qaz@WSX'); jdbcConnectionConfig.addProperty('nullCatalogMeansCurrent', 'true');//MySQL無法識別table標簽中schema類的配置,所以在URL上指明目標數據庫,并追加nullCatalogMeansCurrent屬性為true jdbcConnectionConfig.addProperty('remarksReporting', 'true');//針對oracle數據庫無法讀取表和字段備注 jdbcConnectionConfig.addProperty('useInformationSchema', 'true');//針對mysql數據庫無法讀取表和字段備注 context.setJdbcConnectionConfiguration(jdbcConnectionConfig); /*Model生成器配置*/ JavaModelGeneratorConfiguration javaModelGeneratorConfig = new JavaModelGeneratorConfiguration(); javaModelGeneratorConfig.setTargetProject('permission/src/main/java');//目標項目(源碼主路徑) javaModelGeneratorConfig.setTargetPackage('com.xgclassroom.model');//目標包(Model類文件存放包) context.setJavaModelGeneratorConfiguration(javaModelGeneratorConfig); /*SqlMapper生成器配置(*Mapper.xml類文件),要javaClient生成器類型配合*/ SqlMapGeneratorConfiguration sqlMapGeneratorConfig = new SqlMapGeneratorConfiguration(); sqlMapGeneratorConfig.setTargetProject('permission/src/main/java');//目標項目(源碼主路徑) sqlMapGeneratorConfig.setTargetPackage('com.xgclassroom.mapper');//目標包(*Mapper.xml類文件存放包) context.setSqlMapGeneratorConfiguration(sqlMapGeneratorConfig); /*JavaClient生成器配置(*Mapper.java類文件)*/ JavaClientGeneratorConfiguration javaClientGeneratorConfig = new JavaClientGeneratorConfiguration(); javaClientGeneratorConfig.setConfigurationType('XMLMAPPER');//JavaClient生成器類型(主要有ANNOTATEDMAPPER、MIXEDMAPPER、XMLMAPPER,要Context的TargetRuntime配合) javaClientGeneratorConfig.setTargetProject('permission/src/main/java');//目標項目(源碼主路徑) javaClientGeneratorConfig.setTargetPackage('com.xgclassroom.mapper');//目標包(*Mapper.java類文件存放包) context.setJavaClientGeneratorConfiguration(javaClientGeneratorConfig); /*表生成配置*/ TableConfiguration tableConfig = new TableConfiguration(context); tableConfig.setTableName('%'); GeneratedKey generatedKey = new GeneratedKey('id', 'JDBC', true, null);//設置主鍵列和生成方式 tableConfig.setGeneratedKey(generatedKey); context.addTableConfiguration(tableConfig); Configuration config = new Configuration(); config.addContext(context); return config; }}

然后就是把MyBatis Generator調用過程中原本讀取xml配置文件的地方換掉就可以了:

import org.mybatis.generator.api.MyBatisGenerator;import org.mybatis.generator.config.Configuration;import org.mybatis.generator.internal.DefaultShellCallback;import java.util.ArrayList;import java.util.List;/** * MyBatisGenerator代碼生成器Java調用程序 * * @author 707669522@qq.com * @since 2020-06-13 */public class GeneratorRunner { public static void main(String[] args) { try { List<String> warnings = new ArrayList<String>(); Configuration config; //使用xml配置文件的方式 /*File configFile = new File(GeneratorRunner.class.getClassLoader().getResource('generatorConfig.xml').getPath()); ConfigurationParser cp = new ConfigurationParser(warnings); config = cp.parseConfiguration(configFile);*/ //使用純Java代碼配置的方式 config = GeneratorConfig.getGeneratorConfig(); DefaultShellCallback callback = new DefaultShellCallback(true); MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings); myBatisGenerator.generate(null); } catch (Exception e) { System.out.println(e.getMessage()); e.printStackTrace(); } }}

最后把xml形式的配置也貼上,說不定能幫到某些同學:

<?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> <context targetRuntime='MyBatis3Simple'> <property name='javaFileEncoding' value='UTF-8'/> <plugin type='com.xgclassroom.generator.GeneratorPlugin'></plugin> <commentGenerator> <property name='suppressAllComments' value='true'/> </commentGenerator> <jdbcConnection driverClass='com.mysql.cj.jdbc.Driver' connectionURL='jdbc:mysql://localhost:3306/customer_center?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false' userId='xurm' password='1qaz@WSX'> <!--MySQL無法識別table標簽中schema類的配置,所以在URL上指明目標數據庫,并追加nullCatalogMeansCurrent屬性為true--> <property name='nullCatalogMeansCurrent' value='true'></property> <!-- /*針對oracle數據庫無法讀取表和字段備注*/ --> <property name='remarksReporting' value='true'></property> <!-- /*針對mysql數據庫無法讀取表和字段備注*/ --> <property name='useInformationSchema' value='true'></property> </jdbcConnection> <javaModelGenerator targetPackage='com.xgclassroom.model' targetProject='customer/src/main/java'/> <sqlMapGenerator targetPackage='com.xgclassroom.mapper' targetProject='customer/src/main/java'></sqlMapGenerator> <javaClientGenerator type='XMLMAPPER' targetPackage='com.xgclassroom.mapper' targetProject='customer/src/main/java'/> <!--對于MySQL不要加schema和catalog,會生成{catalog}..{table}的SQL語句,表名填%是表示生成目標庫的所有表--> <table tableName='%'> <!--指定生成主鍵列相關的設置--> <generatedKey column='id' sqlStatement='JDBC'/> </table> </context></generatorConfiguration>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品国产午夜| 麻豆久久一区二区| 韩日一区二区| 亚洲一区二区成人| 粉嫩av一区二区三区四区五区 | 日韩欧美精品综合| 精品免费视频| 日本а中文在线天堂| 日本а中文在线天堂| 日韩精品一区二区三区免费观影 | 日韩精品欧美大片| 亚洲精品麻豆| 久久久国产精品网站| 国产一区二区三区视频在线| 日韩成人午夜精品| 日韩午夜黄色| 四季av一区二区凹凸精品| 久久人人99| 欧美日韩亚洲一区在线观看| 色一区二区三区| 久久国产麻豆精品| 久久国产成人午夜av影院宅| 麻豆精品一区二区综合av| 午夜日韩在线| 秋霞影视一区二区三区| 麻豆久久久久久| 911亚洲精品| 亚洲伊人精品酒店| 亚洲欧美激情诱惑| 亚洲精品在线观看91| 日韩精品看片| 91精品91| 久久国产乱子精品免费女| 婷婷综合六月| 欧美午夜不卡影院在线观看完整版免费| 国产视频一区三区| 中文一区一区三区免费在线观| 日韩不卡手机在线v区| 欧美精品第一区| 少妇久久久久| 日本亚洲视频在线| 激情国产在线| 免费一级片91| 国产一区二区精品福利地址| 亚洲综合五月| 久久狠狠久久| 日韩精品1区2区3区| 国产精品亚洲一区二区三区在线观看| 国产aⅴ精品一区二区四区| 亚洲一区不卡| 日本а中文在线天堂| 91亚洲精品视频在线观看| 99久久99久久精品国产片果冰| 国产欧美日韩在线一区二区| 久久久噜噜噜| 国产中文欧美日韩在线| 国产欧美日韩在线观看视频 | 亚洲ww精品| 波多视频一区| 国产精品一站二站| 快she精品国产999| 日本少妇一区| 国产中文字幕一区二区三区| 日韩精品一级| 夜夜精品视频| 亚洲婷婷在线| a日韩av网址| 国产激情精品一区二区三区| 亚洲青青久久| 日韩精品一区二区三区av | 国产精品av一区二区| 国产精品久久久久久久久久妞妞| 午夜在线精品偷拍| 午夜久久tv| 亲子伦视频一区二区三区| 久久国产精品免费精品3p| 日韩一区欧美二区| 手机精品视频在线观看| 国产综合婷婷| 午夜久久美女| 亚洲激精日韩激精欧美精品| 久久精品动漫| 精品欧美一区二区三区在线观看| 日韩av免费大片| 91亚洲国产| 日韩在线视频精品| 91久久久精品国产| 日韩一级网站| 亚洲尤物av| 麻豆精品视频在线观看| 91亚洲国产| 亚洲一级在线| 国产精品欧美日韩一区| 黄色在线网站噜噜噜| 偷拍欧美精品| 在线一区免费| 欧美日韩1区| 91九色精品| 久久精品国产亚洲一区二区三区| 国产精区一区二区| 成人日韩av| 日本在线精品| 亚洲三级av| 国产精品亚洲欧美一级在线| 国产91在线精品| 欧美 日韩 国产一区二区在线视频| 婷婷中文字幕一区| 欧美在线看片| 欧美日韩在线二区| 欧美日韩伊人| 国产亚洲亚洲| 国产伦理久久久久久妇女| 国产一区精品福利| 欧美天堂亚洲电影院在线观看| 日韩精品91亚洲二区在线观看| 久久伊人亚洲| 亚洲精品韩国| 国产综合亚洲精品一区二| 日韩黄色av| 亚洲神马久久| 美女视频黄 久久| 亚洲精品国产精品粉嫩| 亚洲福利精品| 高清日韩欧美| 欧美日韩精品一区二区三区视频 | 亚洲激情av| 国产91在线播放精品| 性色一区二区| 香蕉久久99| 国产精品久久久久久久免费观看| 一二三区精品| 亚洲一区日韩| 黄页网站一区| 999久久久91| 日本在线高清| 成人午夜网址| 久久av网址| 国产免费久久| 欧美精品国产一区| 亚洲毛片在线| 香蕉久久国产| 日韩午夜在线| 日韩黄色大片| 国产aa精品| 黄色网一区二区| 国产精品xvideos88| 日本不卡视频在线观看| 亚洲网址在线观看| 亚洲色诱最新| 久久不射网站| 日本一区二区三区视频在线看| 久久午夜精品| 日韩有吗在线观看| 日本aⅴ免费视频一区二区三区| 亚洲理论在线| 国产亚洲观看| 国内精品亚洲| 国模大尺度视频一区二区| 国产三级一区| 麻豆久久久久久久| 成人高清一区| av资源亚洲| 首页亚洲欧美制服丝腿| 在线看片一区| 免费一级欧美片在线观看网站| 男女男精品网站| 欧美日韩国产一区精品一区| 久久久天天操| 你懂的亚洲视频| 国产精品1区在线| 久久爱www成人| 国产日韩亚洲欧美精品| 亚洲主播在线| 日韩视频一区| 午夜在线一区| 首页亚洲欧美制服丝腿| 99热精品在线| 乱人伦精品视频在线观看| 精品欧美久久| 亚洲大全视频| 亚洲激情久久| 亚洲精品乱码| 伊人久久国产| 国产欧美在线| 久久不射网站| 久久高清免费| 国产福利亚洲| 99国产精品久久久久久久成人热| 久久国产欧美日韩精品| 午夜视频精品| 日本欧美国产| 欧美日本不卡高清| 男女性色大片免费观看一区二区| 国产精品免费精品自在线观看| 亚洲激情中文| 伊人久久高清| 久久精品二区亚洲w码| 久久福利一区| 亚洲特色特黄| 五月天av在线|