java代码配置 mybatis_使用Java代码配置MyBatis Generator

import org.mybatis.generator.config.*;/*** 基于Java代码的MBG配置

* Maven打包方式为POM的项目或模块(pom),resources目录的内容不会输出到类路径下,所以可以选择直接使用Java代码配置!

*

*@author707669522@qq.com

*@since2020-06-13*/

public classGeneratorConfig {public staticConfiguration getGeneratorConfig() {

Context context= newContext(ModelType.CONDITIONAL);

context.setId("simple");

context.setTargetRuntime("MyBatis3Simple");/*添加属性*/context.addProperty("javaFileEncoding", "UTF-8");/*插件配置,这个是我自己的插件,没有自定义插件的同学可以不配这一节,删除即可*/PluginConfiguration pluginConfig= newPluginConfiguration();

pluginConfig.setConfigurationType("com.xgclassroom.generator.GeneratorPlugin");

context.addPluginConfiguration(pluginConfig);/*注释生成器配置*/CommentGeneratorConfiguration commentGeneratorConfig= newCommentGeneratorConfiguration();

commentGeneratorConfig.addProperty("suppressAllComments", "true");

context.setCommentGeneratorConfiguration(commentGeneratorConfig);/*JDBC连接信息配置*/JDBCConnectionConfiguration jdbcConnectionConfig= newJDBCConnectionConfiguration();

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= newJavaModelGeneratorConfiguration();

javaModelGeneratorConfig.setTargetProject("permission/src/main/java");//目标项目(源码主路径)

javaModelGeneratorConfig.setTargetPackage("com.xgclassroom.model");//目标包(Model类文件存放包)

context.setJavaModelGeneratorConfiguration(javaModelGeneratorConfig);/*SqlMapper生成器配置(*Mapper.xml类文件),要javaClient生成器类型配合*/SqlMapGeneratorConfiguration sqlMapGeneratorConfig= newSqlMapGeneratorConfiguration();

sqlMapGeneratorConfig.setTargetProject("permission/src/main/java");//目标项目(源码主路径)

sqlMapGeneratorConfig.setTargetPackage("com.xgclassroom.mapper");//目标包(*Mapper.xml类文件存放包)

context.setSqlMapGeneratorConfiguration(sqlMapGeneratorConfig);/*JavaClient生成器配置(*Mapper.java类文件)*/JavaClientGeneratorConfiguration javaClientGeneratorConfig= newJavaClientGeneratorConfiguration();

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= newTableConfiguration(context);

tableConfig.setTableName("%");

GeneratedKey generatedKey= new GeneratedKey("id", "JDBC", true, null);//设置主键列和生成方式

tableConfig.setGeneratedKey(generatedKey);

context.addTableConfiguration(tableConfig);

Configuration config= newConfiguration();

config.addContext(context);returnconfig;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值