Springboot+gradle+Mybatis-Generator
1.数据库准备
在mysql中创建一个t_user的数据库,如图1:
2.开发软件:ieda
3.创建Gradle+Springboot+Mybatis项目
file——>new——>Project:
到这一步,我们就创建好项目了,但是还不能运行。之后的工作完成后整个项目的结构是:
4步骤
1.build.gradle配置
buildscript {
ext {
springBootVersion = '2.0.1.RELEASE'
}
repositories {
mavenCentral()
}
dependencies {
classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
}
}
apply plugin: ‘java’
apply plugin: ‘eclipse’
apply plugin: ‘org.springframework.boot’
apply plugin: ‘io.spring.dependency-management’
group = ‘com.jarry’
version = ‘0.0.1-SNAPSHOT’
sourceCompatibility = 1.8
repositories {
mavenCentral()
}
dependencies {
compile(‘org.springframework.boot:spring-boot-starter-web’)
compile(‘org.mybatis.spring.boot:mybatis-spring-boot-starter:1.3.2’)
runtime(‘mysql:mysql-connector-java’)
testCompile(‘org.springframework.boot:spring-boot-starter-test’)
//数据库
compile group: 'org.apache.tomcat', name: 'tomcat-jdbc', version: '8.5.23'
//日志
compile group: 'log4j', name: 'log4j', version: '1.2.17'
//fastjson
compile group: 'com.alibaba', name: 'fastjson', version: '1.2.47'
}
//mybatis generator plugin ------ start
buildscript {
repositories {
maven {
url “https://plugins.gradle.org/m2/”
}
}
dependencies {
classpath “gradle.plugin.com.arenagod.gradle:mybatis-generator-plugin:1.4”
}
}
apply plugin: “com.arenagod.gradle.MybatisGenerator”
configurations {
mybatisGenerator
}
mybatisGenerator {
verbose = true
configFile = ‘src/main/resources/tools/generatorConfig.xml’
}
//mybatis generator plugin ------ end
2.generatorConfig.xml配置(在resource的tools文件夹下),
(1)在resource中创建一个mybatis文件(用于生成mapper.xml);
(2)将配置的文件路径和数据库地址改成自己项目的。
<?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>
<span class="hljs-comment"><!--id:必选,上下文id,用于在生成错误时提示--></span>
<span class="hljs-tag"><<span class="hljs-name">context</span> <span class="hljs-attr">id</span>=<span class="hljs-string">"mysql"</span> <span class="hljs-attr">targetRuntime</span>=<span class="hljs-string">"MyBatis3"</span>></span>
<span class="hljs-comment"><!-- 生成的Java文件的编码 --></span>
<span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"javaFileEncoding"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"UTF-8"</span>/></span>
<span class="hljs-comment"><!-- 对注释进行控制 --></span>
<span class="hljs-tag"><<span class="hljs-name">commentGenerator</span>></span>
<span class="hljs-comment"><!-- suppressDate是去掉生成日期那行注释 --></span>
<span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"suppressDate"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"true"</span>/></span>
<span class="hljs-comment"><!-- suppressAllComments是去掉所有的注解 --></span>
<span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"suppressAllComments"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"true"</span>/></span>
<span class="hljs-tag"></<span class="hljs-name">commentGenerator</span>></span>
<span class="hljs-comment"><!--jdbc的数据库连接 --></span>
<span class="hljs-tag"><<span class="hljs-name">jdbcConnection</span>
<span class="hljs-attr">driverClass</span>=<span class="hljs-string">"com.mysql.jdbc.Driver"</span>
<span class="hljs-attr">connectionURL</span>=<span class="hljs-string">"jdbc:mysql://127.0.0.1:3306/test"</span>
<span class="hljs-attr">userId</span>=<span class="hljs-string">"root"</span>
<span class="hljs-attr">password</span>=<span class="hljs-string">"123456"</span>></span>
<span class="hljs-tag"></<span class="hljs-name">jdbcConnection</span>></span>
<span class="hljs-comment"><!-- java类型处理器
用于处理DB中的类型到Java中的类型,默认使用JavaTypeResolverDefaultImpl;
注意一点,默认会先尝试使用Integer,Long,Short等来对应DECIMAL和 NUMERIC数据类型;
--></span>
<span class="hljs-tag"><<span class="hljs-name">javaTypeResolver</span> <span class="hljs-attr">type</span>=<span class="hljs-string">"org.mybatis.generator.internal.types.JavaTypeResolverDefaultImpl"</span>></span>
<span class="hljs-comment"><!--
true:使用BigDecimal对应DECIMAL和 NUMERIC数据类型
false:默认,
scale>0;length>18:使用BigDecimal;
scale=0;length[10,18]:使用Long;
scale=0;length[5,9]:使用Integer;
scale=0;length<5:使用Short;
--></span>
<span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"forceBigDecimals"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"false"</span>/></span>
<span class="hljs-tag"></<span class="hljs-name">javaTypeResolver</span>></span>
<span class="hljs-comment"><!-- java模型创建器,是必须要的元素
负责:1,key类(见context的defaultModelType);2,java类;3,查询类
targetPackage:生成的类要放的包,真实的包受enableSubPackages属性控制;
targetProject:目标项目,指定一个存在的目录下,生成的内容会放到指定目录中,如果目录不存在,MBG不会自动建目录
--></span>
<span class="hljs-tag"><<span class="hljs-name">javaModelGenerator</span> <span class="hljs-attr">targetPackage</span>=<span class="hljs-string">"com.jarry.time.model"</span> <span class="hljs-attr">targetProject</span>=<span class="hljs-string">"src/main/java"</span>></span>
<span class="hljs-comment"><!-- 是否允许子包,即targetPackage.schemaName.tableName --></span>
<span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"enableSubPackages"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"true"</span>/></span>
<span class="hljs-comment"><!-- 是否对model添加 构造函数 --></span>
<span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"constructorBased"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"true"</span>/></span>
<span class="hljs-comment"><!-- 是否对类CHAR类型的列的数据进行trim操作 --></span>
<span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"trimStrings"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"true"</span>/></span>
<span class="hljs-comment"><!-- 建立的Model对象是否 不可改变 即生成的Model对象不会有 setter方法,只有构造方法 --></span>
<span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"immutable"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"false"</span>/></span>
<span class="hljs-tag"></<span class="hljs-name">javaModelGenerator</span>></span>
<span class="hljs-comment"><!-- 生成SQL map的XML文件生成器,
注意,在Mybatis3之后,我们可以使用mapper.xml文件+Mapper接口(或者不用mapper接口),
或者只使用Mapper接口+Annotation,
所以,如果 javaClientGenerator配置中配置了需要生成XML的话,这个元素就必须配置
targetPackage/targetProject:同javaModelGenerator
--></span>
<span class="hljs-tag"><<span class="hljs-name">sqlMapGenerator</span> <span class="hljs-attr">targetPackage</span>=<span class="hljs-string">"mybatis"</span> <span class="hljs-attr">targetProject</span>=<span class="hljs-string">"src/main/resources"</span>></span>
<span class="hljs-comment"><!-- 在targetPackage的基础上,根据数据库的schema再生成一层package,最终生成的类放在这个package下,默认为false --></span>
<span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"enableSubPackages"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"true"</span>/></span>
<span class="hljs-tag"></<span class="hljs-name">sqlMapGenerator</span>></span>
<span class="hljs-comment"><!-- 对于mybatis来说,即生成Mapper接口,注意,如果没有配置该元素,那么默认不会生成Mapper接口
targetPackage/targetProject:同javaModelGenerator
type:选择怎么生成mapper接口(在MyBatis3/MyBatis3Simple下):
1,ANNOTATEDMAPPER:会生成使用Mapper接口+Annotation的方式创建(SQL生成在annotation中),不会生成对应的XML;
2,MIXEDMAPPER:使用混合配置,会生成Mapper接口,并适当添加合适的Annotation,但是XML会生成在XML中;
3,XMLMAPPER:会生成Mapper接口,接口完全依赖XML;
注意,如果context是MyBatis3Simple:只支持ANNOTATEDMAPPER和XMLMAPPER
--></span>
<span class="hljs-tag"><<span class="hljs-name">javaClientGenerator</span> <span class="hljs-attr">targetPackage</span>=<span class="hljs-string">"com.jarry.time.mapper"</span> <span class="hljs-attr">type</span>=<span class="hljs-string">"XMLMAPPER"</span> <span class="hljs-attr">targetProject</span>=<span class="hljs-string">"src/main/java"</span>></span>
<span class="hljs-comment"><!-- 在targetPackage的基础上,根据数据库的schema再生成一层package,最终生成的类放在这个package下,默认为false --></span>
<span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"enableSubPackages"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"true"</span>/></span>
<span class="hljs-tag"></<span class="hljs-name">javaClientGenerator</span>></span>
<span class="hljs-comment"><!-- 选择一个table来生成相关文件,可以有一个或多个table,必须要有table元素
tableName(必要):要生成对象的表名;
domainObjectName 给表对应的 model 起名字
注意:大小写敏感问题。
--></span>
<span class="hljs-tag"><<span class="hljs-name">table</span> <span class="hljs-attr">tableName</span>=<span class="hljs-string">"t_user"</span> <span class="hljs-attr">domainObjectName</span>=<span class="hljs-string">"User"</span>></span>
<span class="hljs-comment"><!--用来修改表中某个列的属性,一个table元素中可以有多个columnOverride元素哈.
property属性来指定列要生成的属性名称.
--></span>
<span class="hljs-comment"><!--<columnOverride column="username" property="userName" />--></span>
<span class="hljs-tag"></<span class="hljs-name">table</span>></span>
<span class="hljs-comment"><!--<table tableName="person" domainObjectName="Person"/>--></span>
<span class="hljs-comment"><!--<table tableName="department" domainObjectName="Depart"/>--></span>
<span class="hljs-tag"></<span class="hljs-name">context</span>></span>
</generatorConfiguration>
3.点击开关(双击),自动生成文件代码
生成mybatis代码:
4.添加Controller和Service实现增删改查
@RestController
public class UserController extends BaseController {
<span class="hljs-meta">@Autowired</span>
<span class="hljs-keyword">private</span> UserServiceImpl userService;
@RequestMapping("/getUserById")
@ResponseBody
public DefaultResultInfo getUserById(@RequestParam(name = “id”, defaultValue = “1”) long id) {
User user = userService.getUserInfo(id);
if (user != null) {
logger.info(JSONArray.toJSON(user));
}
return new DefaultResultInfo<>(user);
}
}
@Service
public class UserServiceImpl implements UserService {
@Autowired
UserMapper userMapper;
@Override
public void registerUser(User user) {
userMapper.insert(user);
}
@Override
public void login(User user) {
}
@Override
public void logout(User user) {
}
@Override
public User getUserInfo(long id) {
return userMapper.selectByPrimaryKey(id);
}
@Override
public void updateteUserInfo(User user) {
}
@Override
public void updateUserImage() {
}
}
5.修改Application
@SpringBootApplication
@MapperScan(basePackages = "com.jarry.time")
public class TimeApplication {
<span class="hljs-comment">//DataSource配置</span>
<span class="hljs-meta">@Bean</span>
<span class="hljs-meta">@ConfigurationProperties</span>(prefix=<span class="hljs-string">"spring.datasource"</span>)
<span class="hljs-function"><span class="hljs-keyword">public</span> DataSource <span class="hljs-title">dataSource</span><span class="hljs-params">()</span> </span>{
<span class="hljs-keyword">return</span> <span class="hljs-keyword">new</span> DataSource();
}
<span class="hljs-comment">//提供SqlSeesion</span>
<span class="hljs-meta">@Bean</span>
<span class="hljs-function"><span class="hljs-keyword">public</span> SqlSessionFactory <span class="hljs-title">sqlSessionFactoryBean</span><span class="hljs-params">()</span> <span class="hljs-keyword">throws</span> Exception </span>{
SqlSessionFactoryBean sqlSessionFactoryBean = <span class="hljs-keyword">new</span> SqlSessionFactoryBean();
sqlSessionFactoryBean.setDataSource(dataSource());
PathMatchingResourcePatternResolver resolver = <span class="hljs-keyword">new</span> PathMatchingResourcePatternResolver();
sqlSessionFactoryBean.setMapperLocations(resolver.getResources(<span class="hljs-string">"classpath:/mybatis/*.xml"</span>));
<span class="hljs-keyword">return</span> sqlSessionFactoryBean.getObject();
}
<span class="hljs-meta">@Bean</span>
<span class="hljs-function"><span class="hljs-keyword">public</span> PlatformTransactionManager <span class="hljs-title">transactionManager</span><span class="hljs-params">()</span> </span>{
<span class="hljs-keyword">return</span> <span class="hljs-keyword">new</span> DataSourceTransactionManager(dataSource());
}
<span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">static</span> <span class="hljs-keyword">void</span> <span class="hljs-title">main</span><span class="hljs-params">(String[] args)</span> </span>{
SpringApplication.run(TimeApplication.class, args);
}
}
6.配置application.properties
spring.datasource.url=jdbc:mysql:
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
7.点击运行