Springboot+gradle+Mybatis-Generator

Springboot+gradle+Mybatis-Generator

1.数据库准备

在mysql中创建一个t_user的数据库,如图1:


图1.png

2.开发软件:ieda

3.创建Gradle+Springboot+Mybatis项目

file——>new——>Project:

图2.png
图3.png
图4.png
图5.png
图6.png
图7

到这一步,我们就创建好项目了,但是还不能运行。之后的工作完成后整个项目的结构是:


图8.png

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">&lt;!--id:必选,上下文id,用于在生成错误时提示--&gt;</span>
<span class="hljs-tag">&lt;<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>&gt;</span>

    <span class="hljs-comment">&lt;!-- 生成的Java文件的编码 --&gt;</span>
    <span class="hljs-tag">&lt;<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>/&gt;</span>

    <span class="hljs-comment">&lt;!-- 对注释进行控制 --&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">commentGenerator</span>&gt;</span>
        <span class="hljs-comment">&lt;!-- suppressDate是去掉生成日期那行注释 --&gt;</span>
        <span class="hljs-tag">&lt;<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>/&gt;</span>
        <span class="hljs-comment">&lt;!-- suppressAllComments是去掉所有的注解 --&gt;</span>
        <span class="hljs-tag">&lt;<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>/&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">commentGenerator</span>&gt;</span>

    <span class="hljs-comment">&lt;!--jdbc的数据库连接 --&gt;</span>
    <span class="hljs-tag">&lt;<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>&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">jdbcConnection</span>&gt;</span>

    <span class="hljs-comment">&lt;!-- java类型处理器
    用于处理DB中的类型到Java中的类型,默认使用JavaTypeResolverDefaultImpl;
    注意一点,默认会先尝试使用Integer,Long,Short等来对应DECIMAL和 NUMERIC数据类型;
    --&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">javaTypeResolver</span> <span class="hljs-attr">type</span>=<span class="hljs-string">"org.mybatis.generator.internal.types.JavaTypeResolverDefaultImpl"</span>&gt;</span>
        <span class="hljs-comment">&lt;!--
            true:使用BigDecimal对应DECIMAL和 NUMERIC数据类型
            false:默认,
                scale&gt;0;length&gt;18:使用BigDecimal;
                scale=0;length[10,18]:使用Long;
                scale=0;length[5,9]:使用Integer;
                scale=0;length&lt;5:使用Short;
         --&gt;</span>
        <span class="hljs-tag">&lt;<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>/&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">javaTypeResolver</span>&gt;</span>


    <span class="hljs-comment">&lt;!-- java模型创建器,是必须要的元素
        负责:1,key类(见context的defaultModelType);2,java类;3,查询类
        targetPackage:生成的类要放的包,真实的包受enableSubPackages属性控制;
        targetProject:目标项目,指定一个存在的目录下,生成的内容会放到指定目录中,如果目录不存在,MBG不会自动建目录
     --&gt;</span>
    <span class="hljs-tag">&lt;<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>&gt;</span>
        <span class="hljs-comment">&lt;!-- 是否允许子包,即targetPackage.schemaName.tableName --&gt;</span>
        <span class="hljs-tag">&lt;<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>/&gt;</span>
        <span class="hljs-comment">&lt;!-- 是否对model添加 构造函数 --&gt;</span>
        <span class="hljs-tag">&lt;<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>/&gt;</span>
        <span class="hljs-comment">&lt;!-- 是否对类CHAR类型的列的数据进行trim操作 --&gt;</span>
        <span class="hljs-tag">&lt;<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>/&gt;</span>
        <span class="hljs-comment">&lt;!-- 建立的Model对象是否 不可改变  即生成的Model对象不会有 setter方法,只有构造方法 --&gt;</span>
        <span class="hljs-tag">&lt;<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>/&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">javaModelGenerator</span>&gt;</span>

    <span class="hljs-comment">&lt;!-- 生成SQL map的XML文件生成器,
        注意,在Mybatis3之后,我们可以使用mapper.xml文件+Mapper接口(或者不用mapper接口),
            或者只使用Mapper接口+Annotation,
            所以,如果 javaClientGenerator配置中配置了需要生成XML的话,这个元素就必须配置
        targetPackage/targetProject:同javaModelGenerator
     --&gt;</span>
    <span class="hljs-tag">&lt;<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>&gt;</span>
        <span class="hljs-comment">&lt;!-- 在targetPackage的基础上,根据数据库的schema再生成一层package,最终生成的类放在这个package下,默认为false --&gt;</span>
        <span class="hljs-tag">&lt;<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>/&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">sqlMapGenerator</span>&gt;</span>


    <span class="hljs-comment">&lt;!-- 对于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
    --&gt;</span>
    <span class="hljs-tag">&lt;<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>&gt;</span>
        <span class="hljs-comment">&lt;!-- 在targetPackage的基础上,根据数据库的schema再生成一层package,最终生成的类放在这个package下,默认为false --&gt;</span>
        <span class="hljs-tag">&lt;<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>/&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">javaClientGenerator</span>&gt;</span>

    <span class="hljs-comment">&lt;!-- 选择一个table来生成相关文件,可以有一个或多个table,必须要有table元素
        tableName(必要):要生成对象的表名;
        domainObjectName 给表对应的 model 起名字
        注意:大小写敏感问题。
     --&gt;</span>
    <span class="hljs-tag">&lt;<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>&gt;</span>

        <span class="hljs-comment">&lt;!--用来修改表中某个列的属性,一个table元素中可以有多个columnOverride元素哈.
            property属性来指定列要生成的属性名称.
         --&gt;</span>
        <span class="hljs-comment">&lt;!--&lt;columnOverride column="username" property="userName" /&gt;--&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">table</span>&gt;</span>

    <span class="hljs-comment">&lt;!--&lt;table tableName="person" domainObjectName="Person"/&gt;--&gt;</span>
    <span class="hljs-comment">&lt;!--&lt;table tableName="department" domainObjectName="Depart"/&gt;--&gt;</span>

<span class="hljs-tag">&lt;/<span class="hljs-name">context</span>&gt;</span>

</generatorConfiguration>

3.点击开关(双击),自动生成文件代码
图9.png

生成mybatis代码:


图10.png
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://127.0.0.1:3306/yueji?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
7.点击运行
图11.png
8.访问地址:http://localhost:8080/getUserById?id=1
图12.png
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值