mybatis生成mysql代码_如何让 Mybatis 自动生成代码,提高开发效率

Actually being alone is not lonely.The real loneliness is when you miss someone.

其实一个人并不孤单,想念一个人的时候才是真正的孤单。

每日掏心话

你给了生活意境,那么生活才能给你风景。你风声鹤唳,生活也就只好四面楚歌。

来自:cnblogs.com/homejim/p/9782403.html | 责编:乐乐

图 / 图虫

往日回顾:

正文

在使用mybatis过程中, 当手写JavaBean和XML写的越来越多的时候, 就越来越同易出错。这种重复性的工作, 我们当然不希望做那么多。

还好,mybatis为我们提供了强大的代码生成--MybatisGenerator。

通过简单的配置, 我们就可以生成各种类型的实体类, Mapper接口, MapperXML文件, Example对象等。通过这些生成的文件, 我们就可以方便的进行单表进行增删改查的操作。

以下的工具使用的都是IDEA

1 创建代码生成器 1.1 创建Maven项目

1.1.1 菜单上选择新建项目

File | New | Project

1.1.2 选择左侧的Maven

d0cf17389b598edd65efafdb0ca16b7e.png

由于我们只是创建一个普通的项目, 此处点击Next即可。

1.1.3 输入GroupId和ArtifactId

在我的项目中,

GroupId 填 com.homejim.mybatis ArtifactId 填 mybatis-generator

点击Next。

1.1.4Finish

通过以上步骤, 一个普通的Maven项目就创建好了。

1.2 配置 generator.xml

其实名字无所谓, 只要跟下面的pom.xml文件中的对应上就好了。

generatorConfiguration PUBLIC

"-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"

"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd" >

commentGenerator>

driverClass="com.mysql.jdbc.Driver"

connectionURL="jdbc:mysql://localhost:3306/mybatis"

userId="root"

password="jim777"/>

javaTypeResolver>

targetPackage="com.homejim.mybatis.entity"

targetProject=".\src\main\java">

javaModelGenerator>

targetPackage="mybatis/mapper"

targetProject=".\src\main\resources">

sqlMapGenerator>

targetPackage="com.homejim.mybatis.mapper"

targetProject=".\src\main\java">

javaClientGenerator>

context>

generatorConfiguration>

需要改一些内容:

本地数据库驱动程序jar包的全路径(必须要改)。

数据库的相关配置(必须要改)

相关表的配置(必须要改)

实体类生成存放的位置。

MapperXML 生成文件存放的位置。

Mapper 接口存放的位置。

如果不知道怎么改, 请看后面的配置详解。

1.3 配置 pom.xml

在原基础上添加一些内容。

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">

4.0.0modelVersion>

com.homejim.mybatisgroupId>

mybatis-generatorartifactId>

1.0-SNAPSHOTversion>

mybatis-generatorfinalName>

org.mybatis.generatorgroupId>

mybatis-generator-maven-pluginartifactId>

1.3.7version>

src/main/resources/generator.xmlconfigurationFile>

trueverbose>

trueoverwrite>

configuration>

Generate MyBatis Artifactsid>

generategoal>

goals>

execution>

executions>

org.mybatis.generatorgroupId>

mybatis-generator-coreartifactId>

1.3.7version>

dependency>

dependencies>

plugin>

plugins>

build>

需要注意的是configurationFile中的文件指的是generator.xml。因此路径写的是该文件的相对路径, 名称也跟该文件相同。

到此,mybatis-generator就可以使用啦。

1.4 使用及测试

1.4.1 打开 Maven Projects 视图

在 IDEA 上, 打开:

View | Tools | Windwos | Maven Projectsf7760183291ba9f800a70e06861106ef.pngMaven项目窗口

1.4.2 Maven Projects 中双击 mybatis-generator

在右侧此时可以看到 Maven Projects 了。找到 mybatis-generator 插件。

mybatis-generator | Plugins | mybatis-generator | mybatis-generator9be3497f2396ccfff8ca6c41f41bc7c6.png运行插件

1.4.3 双击运行

运行正确后, 生成代码, 得到如下的结构

aba761a6952a27d86ae8be4209402ffe.png

2 XML 配置详解

仅仅是上面那么简单的使用还不够爽。那么我们就可以通过更改 generator.xml 配置文件的方式进行生成的配置。

2.1 优先

推荐查看官方的文档。

英文不错的:官方网站。

中文翻译版:翻译版网站

2.2 官网没有的 2.2.1 property 标签

该标签在官网中只是说用来指定元素的属性, 至于怎么用没有详细的讲解。

2.2.1.1 分隔符相关"autoDelimitKeywords" value="true"/>

"beginningDelimiter" value="`"/>

"endingDelimiter" value="`"/>

以上的配置对应的是mysql,当数据库中的字段和数据库的关键字一样时, 就会使用分隔符。

比如我们的数据列是delete, 按以上的配置后, 在它出现的地方, 就变成delete。

2.2.1.2 编码

默认是使用当前的系统环境的编码, 可以配置为 GBK 或 UTF-8。

"javaFileEncoding" value="UTF-8"/>

我想项目为 UTF-8, 如果指定生成 GBK, 则自动生成的中文就是乱码。

2.2.1.3 格式化

这些显然都是可以自定义实现的的。

2.2.2 plugins 标签

plugins 标签用来扩展或修改代码生成器生成的代码。

在生成的 XML 中, 是没有 **** 这个标签的。该标签是配置缓存的。

如果我们想生成这个标签, 那么可以plugins中进行配置。

plugin>

260d2f5fbe51b8908a295014f4e8da13.pngcache

比如你想生成的JavaBean中自行实现 Serializable 接口。

type="org.mybatis.generator.plugins.SerializablePlugin" />

cc7a6492c35b6d1b1db550cb212dc0bf.png序列化接口实现

还能自定义插件。

这些插件都蛮有用的, 感觉后续可以专门开一篇文章来讲解。

2.2.3 commentGenerator 标签

看名称, 就知道是用来生成注释用的。

默认配置:

commentGenerator>

suppressAllComments:阻止生成注释, 默认值是false。

suppressDate: 阻止生成的注释包含时间戳, 默认为false。

addRemarkComments: 注释中添加数据库的注释, 默认为 false。

还有一个就是我们可以通过 type 属性指定我们自定义的注解实现类, 生成我们自己想要的注解。自定义的实现类需要实现org.mybatis.generator.api.CommentGenerator。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值