一个简单的实现自动生成mybatis的代码demo

    最近,入职了一家新公司,有空余时间去写感兴趣的东西。

    项目开始启动,采用SpringMVC+Spring+Mybatis框架。然后寻找一个简单的自动生成代码工具,没有理想的。所以就自己简单的实现了一个。

    项目架构如下,简单的几个类,与一个配置文件。感兴趣的可以戳这里。需要一个积分,如果嫌弃不值得,可以联系我,我取消积分限制

    

  FieldBean :数据库字段的描述

  Gen*File : 生成文件的类,可以按照自己的需求进行编辑

  GenTest: 程序的调用类,输入表名,模块名,进行生成代码

  NotesUtils: 注解util 可以定制自己style的注解

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
创建自动生成代码的java文件。 (1)先创建一个java Project,然后next,然后选择Create project from template模版, 选中后,点击Java Hello World模版,然后next,出现定义Project名时,写上自己定义的文件名(提示:automatic 自动的,generate 生成,code 代码),然后finsh,这就完成了自动生成文件的创建。 图片1.png 图片2.png 导入相关的lib。 (1) 点击项目,然后创建一个lib的目录,然后将mybatis的三个jar包和关于打印 日志的log4j的jar包导入。 图片3.png (2) 然后选中导入所有的jar包,然后右击,选中Add as lib..,然后在 level 选项 中选择Project Library,这就完成了相关自动生成代码的包的导入。 图片4.png (3) 完成后的目录展示 图片5.png 导入generatorConfig.xml (1) 将generatorConfig.xml放在项目的目录下,与src,lib同一级目录。 图片6.png 修改generatorConfig.xml配置文件。 (1) 修改连接数据库的主机名,数据库。 <!--数据库连接的信息:驱动类、连接地址、用户名、密码 --> ​ <jdbcConnection driverClass="com.mysql.jdbc.Driver" ​ connectionURL="jdbc:mysql://localhost:3306/mybatis" ​ userId="root" password="123456"> ​ </jdbcConnection> connectionURL:修改的是自己连接数据的主机(如果是本机用localhost,如果是远程的话,就输入远程的ip地址)和数据库的名字 userId: 数据库的用户名 Password: 数据库的密码 (2) 修改连接数据库的表名 <!-- 指定数据库表 --> ​ <table schema="" tableName="batis"></table> ​ tableName: 连接数据库中的表名。 如果有多个表名需要连接,可以写多个我们这样的标签,修改tableName中的表名。 (3) 修改自动生成的bean类(或者说Po类,model类)的位置。 <!-- targetProject:生成bean类的位置 --> ​ <javaModelGenerator targetPackage="cn.kz.com.po" ​ targetProject=".\src"> ​ <!-- enableSubPackages:是否让schema作为包的后缀 --> <property name="enableSubPackages" value="false" /> ​ <!-- 从数据库返回的值被清理前后的空格 --> ​ <property name="trimStrings" value="true" /> ​ </javaModelGenerator> ​ targentPackage: 就是我们生成bean类的目录和位置,(生成的包在src/cn/kz/com/po) targetProject: 如果值为”.\src” ,就是将文件创建在src根目录下 (4) 修改生成mapper文件的位置 <!-- targetProject:mapper映射文件生成的位置 --> ​ <sqlMapGenerator targetPackage="cn.kz.com.mapper" ​ targetProject=".\src"> ​ <!-- ​ enableSubPackages:是否让schema作为包的后缀 --> ​ <property name="enableSubPackages" value="false" /> ​ </sqlMapGenerator> ​ (5) 修改生成mapper接口的位置 <!-- targetPackage:mapper接口生成的位置 --> ​ <javaClientGenerator type="XMLMAPPER" targetPackage="cn.kz.com.mapper" ​ targetProject=".\src"> ​ <!-- ​ enableSubPackages:是否让schema作为包的后缀 --> ​ <property name="enableSubPackages" value="false" /> ​ </javaClientGenerator> 将GeneratorSqlmap 类复制到src下。 (1) 如果类不报红,就直接运行(运行前,记得将数据库打开),然后运行如果出现了生成的包和文件,就说明成功,虽然控制台会显示一些红色的日志,但无关紧要。
好的,下面是一个简单mybatis-plus自动生成代码demo: 1. 首先,我们需要在pom.xml文件中添加相关依赖: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-generator</artifactId> <version>3.4.3</version> </dependency> <dependency> <groupId>org.apache.velocity</groupId> <artifactId>velocity-engine-core</artifactId> <version>2.3.0</version> </dependency> ``` 2. 接着,在resources目录下创建一个generator目录,用于存放代码生成器的配置文件。 3. 在generator目录下创建一个generatorConfig.properties文件,用于配置代码生成器的相关参数,具体可以参考如下示例: ```properties # 数据库连接信息 spring.datasource.url=jdbc:mysql://localhost:3306/mybatis_plus_demo?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver # 代码生成器配置 mybatis-plus.global-config.author=your name mybatis-plus.global-config.outputDir=src/main/java mybatis-plus.global-config.enableSwagger=true mybatis-plus.strategy.superEntityClass=com.baomidou.mybatisplus.extension.activerecord.Model mybatis-plus.strategy.superMapperClass=com.baomidou.mybatisplus.core.mapper.BaseMapper mybatis-plus.strategy.superServiceClass=com.baomidou.mybatisplus.extension.service.IService mybatis-plus.strategy.superServiceImplClass=com.baomidou.mybatisplus.extension.service.impl.ServiceImpl mybatis-plus.generator.fileOverride=true mybatis-plus.generator.entityLombokModel=true mybatis-plus.generator.basePackage=com.example.mybatisplus mybatis-plus.generator.controllerPackage=com.example.mybatisplus.controller mybatis-plus.generator.servicePackage=com.example.mybatisplus.service mybatis-plus.generator.serviceImplPackage=com.example.mybatisplus.service.impl mybatis-plus.generator.mapperPackage=com.example.mybatisplus.mapper mybatis-plus.generator.xmlPackage=mapper mybatis-plus.generator.tableNames=user mybatis-plus.generator.includeTables=user ``` 4. 接下来,我们需要编写代码生成器的启动类,具体代码如下: ```java package com.example.mybatisplus.generator; import com.baomidou.mybatisplus.annotation.DbType; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.generator.AutoGenerator; import com.baomidou.mybatisplus.generator.config.DataSourceConfig; import com.baomidou.mybatisplus.generator.config.GlobalConfig; import com.baomidou.mybatisplus.generator.config.PackageConfig; import com.baomidou.mybatisplus.generator.config.StrategyConfig; import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy; /** * mybatis-plus代码生成器 */ public class CodeGenerator { public static void main(String[] args) { // 1. 全局配置 GlobalConfig globalConfig = new GlobalConfig(); globalConfig.setOutputDir("src/main/java"); // 生成文件的输出目录 globalConfig.setAuthor("your name"); // 作者 globalConfig.setOpen(false); // 是否打开输出目录 globalConfig.setFileOverride(true); // 是否覆盖已有文件 globalConfig.setIdType(IdType.AUTO); // 主键类型 globalConfig.setServiceName("%sService"); // Service接口的名称 globalConfig.setBaseResultMap(true); // 是否开启BaseResultMap globalConfig.setBaseColumnList(true); // 是否开启baseColumnList globalConfig.setSwagger2(true); // 是否开启Swagger2 // 2. 数据源配置 DataSourceConfig dataSourceConfig = new DataSourceConfig(); dataSourceConfig.setDbType(DbType.MYSQL); // 数据库类型 dataSourceConfig.setUrl("jdbc:mysql://localhost:3306/mybatis_plus_demo?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC"); dataSourceConfig.setUsername("root"); // 数据库用户名 dataSourceConfig.setPassword("123456"); // 数据库密码 dataSourceConfig.setDriverName("com.mysql.cj.jdbc.Driver"); // 数据库驱动 // 3. 包名配置 PackageConfig packageConfig = new PackageConfig(); packageConfig.setParent("com.example.mybatisplus"); // 包名 packageConfig.setController("controller"); // Controller包名 packageConfig.setEntity("entity"); // Entity包名 packageConfig.setService("service"); // Service包名 packageConfig.setServiceImpl("service.impl"); // ServiceImpl包名 packageConfig.setMapper("mapper"); // Mapper包名 // 4. 策略配置 StrategyConfig strategyConfig = new StrategyConfig(); strategyConfig.setNaming(NamingStrategy.underline_to_camel); // 数据库表映射到实体的命名策略 strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel); // 数据库表字段映射到实体的命名策略 strategyConfig.setEntityLombokModel(true); // 是否使用lombok注解 strategyConfig.setRestControllerStyle(true); // 是否使用RestController注解 strategyConfig.setInclude("user"); // 要生成的表名 strategyConfig.setControllerMappingHyphenStyle(true); // 是否开启controller类名称的连字符风格 // 5. 代码生成器配置 AutoGenerator generator = new AutoGenerator(); generator.setGlobalConfig(globalConfig); generator.setDataSource(dataSourceConfig); generator.setPackageInfo(packageConfig); generator.setStrategy(strategyConfig); generator.execute(); } } ``` 5. 最后,我们只需要运行CodeGenerator类即可自动生成代码。生成的代码会在src/main/java目录下的对应包名中。 以上就是一个简单mybatis-plus自动生成代码demo,希望能帮助到你。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值