**springboot maven配置mybatis generator 生成代码
使用springboot2.0版本以上,我父工程默认引入的的mysql jar包是8.0以上的,
连接mysql数据库的时候要这么写,驱动那里加了cj.的,如果你jar是6.0以下就可以不用加
我用的mysql8.0.感觉遇到了好多坑。。。。。。
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/rootdatabase?useUnicode=true&characterEncoding=utf-8&useSSL=false
spring.datasource.username=root
spring.datasource.password=123456
注意!!!如果你mysql是高版本的,在pom文件标签里引入的mysql jar也要是高版本的,否则在执行命令的时候,会报错,无法连接到mysql -->**
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.4.RELEASE</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>
<groupId>com.my</groupId>
<artifactId>springboot-mybatis-generator</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>springboot-mybatis-generator</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.0.1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.5</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<!-- 自动生成代码插件 -->
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.5</version>
**<!--注意!!!如果你mysql是高版本的,那么这里引入的jar也要是高版本的,否则在执行命令的时候,会报错,无法连接到mysql -->**
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.11</version>
</dependency>
</dependencies>
<configuration>
<!--配置文件的路径 generatorConfig.xml -->
<configurationFile>${basedir}/src/main/resources/generator-config.xml</configurationFile>
<overwrite>true</overwrite>
</configuration>
</plugin>
</plugins>
</build>
</project>
然后generator-cofig 配置文件
需要注意的是,配置文件中,mysql的连接地方,也要加.cj,不过好像不加也行,
,最好用命令行执行,我在eclipse中执行maven命令,报错,最后用了命令行,无奈。。。。cmd进入到项目目录,执行mvn mybatis-generator:generate命令
第一次执行命令不加cj,会告诉类’com.mysql.jdbc.driver’。这已被否决。新的驱动程序类是’com.mysql.cj.jdbc.driver’。驱动程序通过SPI和手册自动注册。
第二次加cj,执行,命令,就没有了,所有还是在配置上加上cj。
注意这个!!!配置
connectionURL="jdbc:mysql://127.0.0.1:3306/rootdatabase?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=GMT"
<!DOCTYPE generatorConfiguration
PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<context id="mysql" targetRuntime="MyBatis3">
<!-- 当表名或者字段名为SQL关键字的时候,可以设置该属性为true,MBG会自动给表名或字段名添加**分隔符**。 -->
<property name="autoDelimitKeywords" value="true" />
<property name="javaFileEncoding" value="UTF-8" />
<!-- 格式化java代码 -->
<property name="javaFormatter" value="org.mybatis.generator.api.dom.DefaultJavaFormatter" />
<!-- 格式化xml -->
<property name="xmlFormatter" value="org.mybatis.generator.api.dom.DefaultXmlFormatter" />
<property name="beginningDelimiter" value="`" />
<property name="endingDelimiter" value="`" />
<!-- 生成的pojo,将implements Serializable -->
<plugin type="org.mybatis.generator.plugins.SerializablePlugin"></plugin>
<!-- <plugin type="org.mybatis.generator.plugin.ext.impl.MysqlPaginationPlugin"></plugin> -->
<!-- <plugin type="org.mybatis.generator.plugin.ext.impl.EntityNullPlugin"></plugin>-->
<commentGenerator>
<!-- type="org.mybatis.generator.plugin.ext.impl.CommentExtGenerator"> -->
<!--阻止生成注释 false为生成-->
<property name="suppressAllComments" value="false" />
<property name="javaFileEncoding" value="UTF-8" />
<!--阻止生成日期 false为生成-->
<property name="suppressDate" value="false" />
<property name="addRemarkComments" value="true" />
</commentGenerator>
<!--数据库链接URL,用户名、密码 -->
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://127.0.0.1:3306/rootdatabase?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=GMT"
userId="root" password="123456">
<property name="useInformationSchema" value="true" />
<property name="remarksReporting" value="true" />
</jdbcConnection>
<!-- java类型处理器 用于处理DB中的类型到Java中的类型,默认使用JavaTypeResolverDefaultImpl; 注意一点,默认会先尝试使用Integer,Long,Short等来对应DECIMAL和
NUMERIC数据类型; -->
<javaTypeResolver
type="org.mybatis.generator.internal.types.JavaTypeResolverDefaultImpl">
<property name="forceBigDecimals" value="false" />
</javaTypeResolver>
<!-- 生成模型的包名和位置 java实体类 -->
<javaModelGenerator
targetPackage="com.springboot.enty" targetProject="src/main/java">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!-- 生成映射文件的包名和位置 -->
<sqlMapGenerator targetPackage="mapp"
targetProject="src/main/resources">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
<!-- 生成DAO的包名和位置 -->
<javaClientGenerator type="XMLMAPPER"
targetPackage="com.springboot.mapper" targetProject="src/main/java">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
<table tableName="stu" domainObjectName="Stu"
enableCountByExample="false" enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false"
selectByExampleQueryId="false">
</table>
</context>
</generatorConfiguration>
使用main方式启动的mybatis generator插件
需要下面这个类,还有mybatis generator的配置文件放到resources目录下,然后引入jar包
注意,你的mysql是高版本的话,mysql jar也要高版本,要不然运行main方法,连接不上mysql
mybatis generator的配置文件就不贴了,和上面maven那种方式的一样
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.11</version>
</dependency>
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.5</version>
</dependency>
public class GeneratorStart {
public static void main(String[] args) throws Exception {
List warnings = new ArrayList();
boolean overwrite = true;
//获取类加载器
ClassLoader classloader = Thread.currentThread().getContextClassLoader();
//类加载器在classpach:下获取配置文件
InputStream is = classloader.getResourceAsStream("generator-config.xml");
ConfigurationParser cp = new ConfigurationParser(warnings);
Configuration config = cp.parseConfiguration(is);
DefaultShellCallback callback = new DefaultShellCallback(overwrite);
MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
myBatisGenerator.generate(null);
}
总结:使用mybatis generator插件的时候,高版本的mysql数据库,一定要用高版本的mysql jar包,
要不然会连不上