- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章mybatis根据表逆向自动化生成代码的实现由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
mybatis自动生成实体类、mapper文件、mapper.xml文件 。
若采用mybatis框架,数据库新建表,手动编写的话,需要编写大量的实体类、mapper文件、mapper.xml文件,都是一些重复且有规律的工作.
我们可以引用插件,然后做配置,自动生成这些文件,提供工作效率.
本博客包含的内容:
①自动生成插件的引入 。
②定义配置文件 。
③运行插件,生成代码 。
在项目的pom文件中引入generator插件 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
<
plugin
>
<
groupId
>org.mybatis.generator</
groupId
>
<
artifactId
>mybatis-generator-maven-plugin</
artifactId
>
<
version
>1.3.7</
version
>
<
configuration
>
<!-- 配置文件存放路径 -->
<
configurationFile
>${basedir}/src/main/resources/generator/generatorConfig.xml</
configurationFile
>
<
overwrite
>true</
overwrite
>
<
verbose
>true</
verbose
>
</
configuration
>
<
dependencies
>
<!-- mysql -->
<
dependency
>
<
groupId
>mysql</
groupId
>
<
artifactId
>mysql-connector-java</
artifactId
>
<
version
>5.1.46</
version
>
</
dependency
>
<!-- mapper -->
<
dependency
>
<
groupId
>tk.mybatis</
groupId
>
<
artifactId
>mapper</
artifactId
>
<
version
>3.4.1</
version
>
</
dependency
>
</
dependencies
>
</
plugin
>
|
注:generatorConfig.xml 一定要放在pom中插件配置的路径下.
下面给出配置文件中的代码,代码中都有注释。主要注意的点有:
①jdbc连接 数据库的路径 。
②生成实体类存放的路劲 。
③生成mapper.xml存放的路劲 。
④生成mapper文件的存放路径 。
⑤修改表以及该表对应的实体类名称 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
<?
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
>
<!--classPathEntry:数据库的JDBC驱动,换成你自己的驱动位置 可选 -->
<!-- <classPathEntry location="F://jdbc//mysql-connector-java-8.0.18.jar"/>-->
<!-- 一个数据库一个context -->
<
context
id
=
"DB2Tables"
targetRuntime
=
"Mybatis3"
>
<!-- 自动识别数据库关键字,默认false,如果设置为true,根据SqlReservedWords中定义的关键字列表;一般保留默认值,遇到数据库关键字(Java关键字),使用columnOverride覆盖 -->
<
property
name
=
"autoDelimitKeywords"
value
=
"true"
/>
<!-- 生成的Java文件的编码 -->
<
property
name
=
"javaFileEncoding"
value
=
"utf-8"
/>
<!-- beginningDelimiter和endingDelimiter:指明数据库的用于标记数据库对象名的符号,比如ORACLE就是双引号,MYSQL默认是`单引号; -->
<
property
name
=
"beginningDelimiter"
value
=
"`"
/>
<
property
name
=
"endingDelimiter"
value
=
"`"
/>
<!-- 格式化java代码 -->
<
property
name
=
"javaFormatter"
value
=
"org.mybatis.generator.api.dom.DefaultJavaFormatter"
/>
<!-- 格式化XML代码 -->
<
property
name
=
"xmlFormatter"
value
=
"org.mybatis.generator.api.dom.DefaultXmlFormatter"
/>
<
plugin
type
=
"org.mybatis.generator.plugins.SerializablePlugin"
/>
<
plugin
type
=
"org.mybatis.generator.plugins.ToStringPlugin"
/>
<!-- 配置 tk.mybatis 插件 -->
<
plugin
type
=
"tk.mybatis.mapper.generator.MapperPlugin"
>
<
property
name
=
"mappers"
value
=
"com.glsx.plat.mybatis.mapper.CommonBaseMapper"
/>
</
plugin
>
<!--配置生成注释信息,最多配置一个 -->
<
commentGenerator
>
<!-- 阻止生成注释包含时间戳 默认为false -->
<
property
name
=
"suppressDate"
value
=
"true"
/>
<!-- 注释是否添加数据库表的备注信息 默认为false -->
<
property
name
=
"addRemarkComments"
value
=
"true"
/>
</
commentGenerator
>
<!-- jdbc连接-->
<
jdbcConnection
driverClass
=
"com.mysql.cj.jdbc.Driver"
connectionURL
=
"jdbc:mysql://127.0.0.1:3307/test?serverTimeZone=Shanghai&useUnicode=true&characterEncoding=utf8&useSSL=false"
userId
=
"root"
password
=
"root"
>
<!--防止生成其他库同名表-->
<
property
name
=
"nullCatalogMeansCurrent"
value
=
"true"
/>
</
jdbcConnection
>
<!-- 类型转换 -->
<
javaTypeResolver
>
<!-- 是否使用bigDecimal, false可自动转化以下类型(Long, Integer, Short, etc.) -->
<
property
name
=
"forceBigDecimals"
value
=
"false"
/>
</
javaTypeResolver
>
<!-- 生成实体类地址 -->
<
javaModelGenerator
targetPackage
=
"cn.com.glsx.admin.modules.entity"
targetProject
=
"src/main/java"
>
<!-- 是否让schema作为包的后缀 -->
<
property
name
=
"enableSubPackages"
value
=
"true"
/>
<!-- 从数据库返回的值去掉前后空格 -->
<
property
name
=
"trimStrings"
value
=
"true"
/>
</
javaModelGenerator
>
<!-- 生成mapper.xml文件存放地址 -->
<
sqlMapGenerator
targetPackage
=
"mapper"
targetProject
=
"src/main/resources"
>
<
property
name
=
"enableSubPackages"
value
=
"true"
/>
</
sqlMapGenerator
>
<!-- 生成接口dao type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper对象 type="MIXEDMAPPER", 生成基于注解的Java Model 和相应的Mapper对象 type="XMLMAPPER",生成SQLMap XML文件和独立的Mapper接口 -->
<
javaClientGenerator
targetPackage
=
"cn.com.glsx.admin.modules.mapper"
targetProject
=
"src/main/java"
type
=
"XMLMAPPER"
>
<
property
name
=
"enableSubPackages"
value
=
"false"
/>
</
javaClientGenerator
>
<!-- table可以有多个,每个数据库中的表都可以写一个table,tableName表示要匹配的数据库表,也可以在tableName属性中通过使用%通配符来匹配所有数据库表, 只有匹配的表才会自动生成文件 enableSelectByPrimaryKey相应的配置表示是否生成相应的接口 -->
<
table
tableName
=
"d_user"
domainObjectName
=
"User"
enableCountByExample
=
"false"
enableUpdateByExample
=
"false"
enableDeleteByExample
=
"false"
enableSelectByExample
=
"false"
selectByExampleQueryId
=
"false"
/>
<
table
tableName
=
"d_student"
domainObjectName
=
"Student"
enableCountByExample
=
"false"
enableUpdateByExample
=
"false"
enableDeleteByExample
=
"false"
enableSelectByExample
=
"false"
selectByExampleQueryId
=
"false"
/>
</
context
>
</
generatorConfiguration
>
|
双击插件,运行后,在控制台中能看到BUILD SUCCESS,说明运行成功.
若在项目中没有,鼠标右击项目,则重新刷新整个项目或者重新加载项目,就可以在配置的路径下看到生成的文件.
到此这篇关于mybatis根据表逆向自动化生成代码的实现的文章就介绍到这了,更多相关mybatis 表逆向自动化生成代码内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://www.cnblogs.com/sun-flower1314/p/15107270.html 。
最后此篇关于mybatis根据表逆向自动化生成代码的实现的文章就讲到这里了,如果你想了解更多关于mybatis根据表逆向自动化生成代码的实现的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 5 年前。 Improve t
背景 我有一个 Azure Runbook(名为 RunStoredProcedure2),定义如下: param( [parameter(Mandatory=$True)] [string] $Sq
我有一个名为“团队”的表,其中包含“非事件”列,另一个表“事件”,其中包含“时间”列。如果任何团队的“事件”中的最新日期发生在 X 时间之前,如何将“非事件”列更新(为 true)? 我知道这可以通过
下面的问题可能有点令人困惑,但我会尽力以最好的方式解释它。 假设我们为一家制造公司工作。它制造然后用于制造产品的组件。在以下示例中,有 3 个组件和 2 个最终产品。 组件和产品的需求如下: comp
我有代码可以让我在一个范围内选择一个项目: COleVariant vItems = cstrAddr; hr = AutoWrap(
我正在开发一个应用程序,该应用程序有 4 种语言的大约 50 个应用内购买,这给了我很多表单和子表单、框和子框,需要使用 iTunesConnect 的令人痛苦且设计糟糕的表单来填充。 我想知道是否有
我想在 Azure 自动化中使用 powershell 脚本来安排打开/关闭资源。 我想在不创建帐户的情况下执行此操作,因为我们的域强制重置密码。我知道自动化帐户会创建一个证书 - 当使用资源管理器(
我尝试从 azure 自动化 run book power shell 自动检索 azure SQL 数据库中的数据。我发现azure自动化帐户的模块中缺少SQL Server模块。我已经导入了该模块
我正在自动化 Outlook,并且需要控制电子邮件的发件人身份。用户将在 Outlook 中设置两个或多个帐户,我需要能够选择从哪个帐户发送电子邮件。有什么想法吗? 需要 Outlook 2003 及
我尝试从 azure 自动化 run book power shell 自动检索 azure SQL 数据库中的数据。我发现azure自动化帐户的模块中缺少SQL Server模块。我已经导入了该模块
假设我有一个网站,我可以(随时)登录并每隔 x 小时提交数据(单击登录后可见的链接),我将如何自动化此过程? 我构建了一个图形用户界面,它为用户(现在是我,为了我自己的方便)提供了一个包含一些信息的界
我正在开发一个程序,它的任务是我们为它定义一些号码(我们的一些手机号码)并且它应该在 Telegram 中注册它们,然后获取发送到该号码的所有消息。如您所知,在 Telegram 中注册需要提供电话号
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 3 年前。 Improve this qu
最近我在处理 CSS Sprite 。一切正常。 我创建了一个 sprite、.css 文件和 html 结构。看起来像 .sprites{ background-image:url
我想为一款名为 Dune 2000 的策略游戏创建一个叠加层。令人讨厌的是,要创建 10 个士兵,每次完成一个都必须单击该图标。没有队列。因此,在不干扰游戏运行方式的情况下,我想听听鼠标移动的声音,当
我是 python 的初学者,我想从自动化开始。以下是我正在尝试执行的任务。 ssh -p 2024 root@10.54.3.32 root@10.54.3.32's password: 我尝试通过
当我将一些 urlencoded Javascript 粘贴到 Firefox 和 Chrome 上的 URL 时,我看到了一些奇怪的事情发生。是否可以使用此技术告诉 Chrome 访问 URL,然后
我需要将大量请求自动提交到基于云的数据库接口(interface) (Intelex)。没有任何方法可以批量提交某些操作,但是提交单个请求所必需的只是让经过身份验证的用户尝试打开 Web 链接。因此,
假设我有一个进程的内存转储。我想对其运行报告,所以基本上我想打开 WinDBG,加载 SOS 并运行一个脚本,该脚本运行一些命令,解析输出,然后基于此运行更多命令。 除了像 SendKeys 这样的
我正在使用 ffmpeg 创建视频剪辑。我想自动化该过程并保存剪辑,而无需手动为要保存的每个文件命名。这是我拥有的代码。它将创建并保存剪辑,但只能使用扩展名和不是名字。 @echo off cd /d
我是一名优秀的程序员,十分优秀!