springboot maven插件 mybatis generator 以及main方式启动的mybatis generator

**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命令
springboot maven插件 mybatis generator 以及main方式启动的mybatis generator_第1张图片第一次执行命令不加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包,
要不然会连不上

你可能感兴趣的:(java学习)