Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mybatis-generator-plugin
Project overview
Project overview
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
mybatis-generator-plugin
Commits
c2fe5274
Commit
c2fe5274
authored
May 29, 2018
by
hewei
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bug:ModelColumnPlugin插件对于alias属性以及关键词处理有问题
parent
f9f6bcdf
Changes
9
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
271 additions
and
11 deletions
+271
-11
src/main/java/com/itfsw/mybatis/generator/plugins/BatchInsertPlugin.java
...om/itfsw/mybatis/generator/plugins/BatchInsertPlugin.java
+1
-1
src/main/java/com/itfsw/mybatis/generator/plugins/IncrementsPlugin.java
...com/itfsw/mybatis/generator/plugins/IncrementsPlugin.java
+3
-3
src/main/java/com/itfsw/mybatis/generator/plugins/ModelColumnPlugin.java
...om/itfsw/mybatis/generator/plugins/ModelColumnPlugin.java
+108
-1
src/main/java/com/itfsw/mybatis/generator/plugins/SelectSelectivePlugin.java
...tfsw/mybatis/generator/plugins/SelectSelectivePlugin.java
+1
-1
src/main/java/com/itfsw/mybatis/generator/plugins/SelectiveEnhancedPlugin.java
...sw/mybatis/generator/plugins/SelectiveEnhancedPlugin.java
+3
-3
src/main/java/com/itfsw/mybatis/generator/plugins/UpsertPlugin.java
...ava/com/itfsw/mybatis/generator/plugins/UpsertPlugin.java
+2
-2
src/test/java/com/itfsw/mybatis/generator/plugins/BugFixedTest.java
...ava/com/itfsw/mybatis/generator/plugins/BugFixedTest.java
+67
-0
src/test/resources/scripts/BugFixedTest/bug-0001.sql
src/test/resources/scripts/BugFixedTest/bug-0001.sql
+28
-0
src/test/resources/scripts/BugFixedTest/bug-0001.xml
src/test/resources/scripts/BugFixedTest/bug-0001.xml
+58
-0
No files found.
src/main/java/com/itfsw/mybatis/generator/plugins/BatchInsertPlugin.java
View file @
c2fe5274
...
...
@@ -231,7 +231,7 @@ public class BatchInsertPlugin extends BasePlugin {
foreachInsertColumns
.
addAttribute
(
new
Attribute
(
"collection"
,
"selective"
));
foreachInsertColumns
.
addAttribute
(
new
Attribute
(
"item"
,
"column"
));
foreachInsertColumns
.
addAttribute
(
new
Attribute
(
"separator"
,
","
));
foreachInsertColumns
.
addElement
(
new
TextElement
(
"${column.
valu
e}"
));
foreachInsertColumns
.
addElement
(
new
TextElement
(
"${column.
escapedColumnNam
e}"
));
eles
.
add
(
foreachInsertColumns
);
...
...
src/main/java/com/itfsw/mybatis/generator/plugins/IncrementsPlugin.java
View file @
c2fe5274
...
...
@@ -329,7 +329,7 @@ public class IncrementsPlugin extends BasePlugin implements IModelBuilderPluginH
sb
.
append
(
"column.value"
);
when
.
addAttribute
(
new
Attribute
(
"test"
,
sb
.
toString
()));
when
.
addElement
(
new
TextElement
(
"${column.
value} = ${column.valu
e} ${record."
+
FIELD_INC_MAP
+
"."
when
.
addElement
(
new
TextElement
(
"${column.
escapedColumnName} = ${column.escapedColumnNam
e} ${record."
+
FIELD_INC_MAP
+
"."
+
introspectedColumn
.
getActualColumnName
()
+
".value} #{record.${column.javaProperty},jdbcType=${column.jdbcType}}"
));
choose
.
addElement
(
when
);
...
...
@@ -338,13 +338,13 @@ public class IncrementsPlugin extends BasePlugin implements IModelBuilderPluginH
if
(
versionColumn
==
null
)
{
XmlElement
otherwise
=
new
XmlElement
(
"otherwise"
);
otherwise
.
addElement
(
new
TextElement
(
"${column.
valu
e} = #{record.${column.javaProperty},jdbcType=${column.jdbcType}}"
));
otherwise
.
addElement
(
new
TextElement
(
"${column.
escapedColumnNam
e} = #{record.${column.javaProperty},jdbcType=${column.jdbcType}}"
));
choose
.
addElement
(
otherwise
);
}
else
{
XmlElement
when
=
new
XmlElement
(
"when"
);
when
.
addAttribute
(
new
Attribute
(
"test"
,
"column.value != '"
+
versionColumn
.
getActualColumnName
()
+
"'.toString()"
));
when
.
addElement
(
new
TextElement
(
"${column.
valu
e} = #{record.${column.javaProperty},jdbcType=${column.jdbcType}}"
));
when
.
addElement
(
new
TextElement
(
"${column.
escapedColumnNam
e} = #{record.${column.javaProperty},jdbcType=${column.jdbcType}}"
));
choose
.
addElement
(
when
);
}
...
...
src/main/java/com/itfsw/mybatis/generator/plugins/ModelColumnPlugin.java
View file @
c2fe5274
...
...
@@ -23,6 +23,7 @@ import org.mybatis.generator.api.IntrospectedColumn;
import
org.mybatis.generator.api.IntrospectedTable
;
import
org.mybatis.generator.api.dom.java.*
;
import
org.mybatis.generator.internal.util.JavaBeansUtil
;
import
org.mybatis.generator.internal.util.StringUtility
;
/**
* ---------------------------------------------------------------------------
...
...
@@ -35,6 +36,12 @@ import org.mybatis.generator.internal.util.JavaBeansUtil;
public
class
ModelColumnPlugin
extends
BasePlugin
{
public
static
final
String
ENUM_NAME
=
"Column"
;
// 内部Enum名
public
static
final
String
METHOD_EXCLUDES
=
"excludes"
;
// 方法名
public
static
final
String
METHOD_GET_ESCAPED_COLUMN_NAME
=
"getEscapedColumnName"
;
// 方法名
public
static
final
String
METHOD_GET_ALIASED_ESCAPED_COLUMN_NAME
=
"getAliasedEscapedColumnName"
;
// 方法名
public
static
final
String
CONST_BEGINNING_DELIMITER
=
"BEGINNING_DELIMITER"
;
// const
public
static
final
String
CONST_ENDING_DELIMITER
=
"ENDING_DELIMITER"
;
// const
public
static
final
String
CONST_TABLE_ALIAS
=
"TABLE_ALIAS"
;
// const
/**
* Model Methods 生成
...
...
@@ -88,6 +95,29 @@ public class ModelColumnPlugin extends BasePlugin {
commentGenerator
.
addEnumComment
(
innerEnum
,
introspectedTable
);
logger
.
debug
(
"itfsw(数据Model属性对应Column获取插件):"
+
topLevelClass
.
getType
().
getShortName
()
+
"增加内部Builder类。"
);
// 生成常量
Field
beginningDelimiterField
=
JavaElementGeneratorTools
.
generateField
(
CONST_BEGINNING_DELIMITER
,
JavaVisibility
.
PRIVATE
,
FullyQualifiedJavaType
.
getStringInstance
(),
"\""
+
StringUtility
.
escapeStringForJava
(
context
.
getBeginningDelimiter
())
+
"\""
);
beginningDelimiterField
.
setStatic
(
true
);
beginningDelimiterField
.
setFinal
(
true
);
commentGenerator
.
addFieldComment
(
beginningDelimiterField
,
introspectedTable
);
innerEnum
.
addField
(
beginningDelimiterField
);
Field
endingDelimiterField
=
JavaElementGeneratorTools
.
generateField
(
CONST_ENDING_DELIMITER
,
JavaVisibility
.
PRIVATE
,
FullyQualifiedJavaType
.
getStringInstance
(),
"\""
+
StringUtility
.
escapeStringForJava
(
context
.
getEndingDelimiter
())
+
"\""
);
endingDelimiterField
.
setStatic
(
true
);
endingDelimiterField
.
setFinal
(
true
);
commentGenerator
.
addFieldComment
(
endingDelimiterField
,
introspectedTable
);
innerEnum
.
addField
(
endingDelimiterField
);
// 生成属性和构造函数
Field
columnField
=
new
Field
(
"column"
,
FullyQualifiedJavaType
.
getStringInstance
());
columnField
.
setVisibility
(
JavaVisibility
.
PRIVATE
);
...
...
@@ -95,6 +125,12 @@ public class ModelColumnPlugin extends BasePlugin {
commentGenerator
.
addFieldComment
(
columnField
,
introspectedTable
);
innerEnum
.
addField
(
columnField
);
Field
isColumnNameDelimitedField
=
new
Field
(
"isColumnNameDelimited"
,
FullyQualifiedJavaType
.
getBooleanPrimitiveInstance
());
isColumnNameDelimitedField
.
setVisibility
(
JavaVisibility
.
PRIVATE
);
isColumnNameDelimitedField
.
setFinal
(
true
);
commentGenerator
.
addFieldComment
(
isColumnNameDelimitedField
,
introspectedTable
);
innerEnum
.
addField
(
isColumnNameDelimitedField
);
Field
javaPropertyField
=
new
Field
(
"javaProperty"
,
FullyQualifiedJavaType
.
getStringInstance
());
javaPropertyField
.
setVisibility
(
JavaVisibility
.
PRIVATE
);
javaPropertyField
.
setFinal
(
true
);
...
...
@@ -134,9 +170,11 @@ public class ModelColumnPlugin extends BasePlugin {
constructor
.
addBodyLine
(
"this.column = column;"
);
constructor
.
addBodyLine
(
"this.javaProperty = javaProperty;"
);
constructor
.
addBodyLine
(
"this.jdbcType = jdbcType;"
);
constructor
.
addBodyLine
(
"this.isColumnNameDelimited = isColumnNameDelimited;"
);
constructor
.
addParameter
(
new
Parameter
(
FullyQualifiedJavaType
.
getStringInstance
(),
"column"
));
constructor
.
addParameter
(
new
Parameter
(
FullyQualifiedJavaType
.
getStringInstance
(),
"javaProperty"
));
constructor
.
addParameter
(
new
Parameter
(
FullyQualifiedJavaType
.
getStringInstance
(),
"jdbcType"
));
constructor
.
addParameter
(
new
Parameter
(
FullyQualifiedJavaType
.
getBooleanPrimitiveInstance
(),
"isColumnNameDelimited"
));
commentGenerator
.
addGeneralMethodComment
(
constructor
,
introspectedTable
);
FormatTools
.
addMethodWithBestPosition
(
innerEnum
,
constructor
);
logger
.
debug
(
"itfsw(数据Model属性对应Column获取插件):"
+
topLevelClass
.
getType
().
getShortName
()
+
".Column增加构造方法和column属性。"
);
...
...
@@ -153,7 +191,9 @@ public class ModelColumnPlugin extends BasePlugin {
sb
.
append
(
introspectedColumn
.
getJavaProperty
());
sb
.
append
(
"\", \""
);
sb
.
append
(
introspectedColumn
.
getJdbcTypeName
());
sb
.
append
(
"\")"
);
sb
.
append
(
"\", "
);
sb
.
append
(
introspectedColumn
.
isColumnNameDelimited
());
sb
.
append
(
")"
);
innerEnum
.
addEnumConstant
(
sb
.
toString
());
logger
.
debug
(
"itfsw(数据Model属性对应Column获取插件):"
+
topLevelClass
.
getType
().
getShortName
()
+
".Column增加"
+
field
.
getName
()
+
"枚举。"
);
...
...
@@ -197,6 +237,73 @@ public class ModelColumnPlugin extends BasePlugin {
FormatTools
.
addMethodWithBestPosition
(
innerEnum
,
mExcludes
);
logger
.
debug
(
"itfsw(数据Model属性对应Column获取插件):"
+
topLevelClass
.
getType
().
getShortName
()
+
".Column增加excludes方法。"
);
// getEscapedColumnName
Method
mGetEscapedColumnName
=
JavaElementGeneratorTools
.
generateMethod
(
METHOD_GET_ESCAPED_COLUMN_NAME
,
JavaVisibility
.
PUBLIC
,
FullyQualifiedJavaType
.
getStringInstance
()
);
commentGenerator
.
addGeneralMethodComment
(
mGetEscapedColumnName
,
introspectedTable
);
JavaElementGeneratorTools
.
generateMethodBody
(
mGetEscapedColumnName
,
"if (this.isColumnNameDelimited) {"
,
"StringBuilder sb = new StringBuilder();"
,
"sb.append("
+
CONST_BEGINNING_DELIMITER
+
");"
,
"sb.append(this.column);"
,
"sb.append("
+
CONST_ENDING_DELIMITER
+
");"
,
"return sb.toString();"
,
"} else {"
,
"return this.column;"
,
"}"
);
FormatTools
.
addMethodWithBestPosition
(
innerEnum
,
mGetEscapedColumnName
);
logger
.
debug
(
"itfsw(数据Model属性对应Column获取插件):"
+
topLevelClass
.
getType
().
getShortName
()
+
".Column增加getEscapedColumnName方法。"
);
// getAliasedEscapedColumnName
if
(
StringUtility
.
stringHasValue
(
introspectedTable
.
getTableConfiguration
().
getAlias
()))
{
// 生成常量
Field
tableAliasField
=
JavaElementGeneratorTools
.
generateField
(
CONST_TABLE_ALIAS
,
JavaVisibility
.
PRIVATE
,
FullyQualifiedJavaType
.
getStringInstance
(),
"\""
+
StringUtility
.
escapeStringForJava
(
introspectedTable
.
getTableConfiguration
().
getAlias
())
+
"\""
);
tableAliasField
.
setStatic
(
true
);
tableAliasField
.
setFinal
(
true
);
commentGenerator
.
addFieldComment
(
tableAliasField
,
introspectedTable
);
innerEnum
.
addField
(
tableAliasField
);
Method
mGetAliasedEscapedColumnName
=
JavaElementGeneratorTools
.
generateMethod
(
METHOD_GET_ALIASED_ESCAPED_COLUMN_NAME
,
JavaVisibility
.
PUBLIC
,
FullyQualifiedJavaType
.
getStringInstance
()
);
commentGenerator
.
addGeneralMethodComment
(
mGetAliasedEscapedColumnName
,
introspectedTable
);
JavaElementGeneratorTools
.
generateMethodBody
(
mGetAliasedEscapedColumnName
,
"StringBuilder sb = new StringBuilder();"
,
"sb.append("
+
CONST_TABLE_ALIAS
+
");"
,
"sb.append('.');"
,
"sb.append(this.getEscapedColumnName());"
,
"return sb.toString();"
);
FormatTools
.
addMethodWithBestPosition
(
innerEnum
,
mGetAliasedEscapedColumnName
);
logger
.
debug
(
"itfsw(数据Model属性对应Column获取插件):"
+
topLevelClass
.
getType
().
getShortName
()
+
".Column增加getAliasedEscapedColumnName方法。"
);
}
else
{
Method
mGetAliasedEscapedColumnName
=
JavaElementGeneratorTools
.
generateMethod
(
METHOD_GET_ALIASED_ESCAPED_COLUMN_NAME
,
JavaVisibility
.
PUBLIC
,
FullyQualifiedJavaType
.
getStringInstance
()
);
commentGenerator
.
addGeneralMethodComment
(
mGetAliasedEscapedColumnName
,
introspectedTable
);
JavaElementGeneratorTools
.
generateMethodBody
(
mGetAliasedEscapedColumnName
,
"return this."
+
METHOD_GET_ESCAPED_COLUMN_NAME
+
"();"
);
FormatTools
.
addMethodWithBestPosition
(
innerEnum
,
mGetAliasedEscapedColumnName
);
logger
.
debug
(
"itfsw(数据Model属性对应Column获取插件):"
+
topLevelClass
.
getType
().
getShortName
()
+
".Column增加getAliasedEscapedColumnName方法。"
);
}
return
innerEnum
;
}
}
src/main/java/com/itfsw/mybatis/generator/plugins/SelectSelectivePlugin.java
View file @
c2fe5274
...
...
@@ -336,7 +336,7 @@ public class SelectSelectivePlugin extends BasePlugin implements ISelectOneByExa
keysEle
.
addAttribute
(
new
Attribute
(
"collection"
,
"selective"
));
keysEle
.
addAttribute
(
new
Attribute
(
"item"
,
"column"
));
keysEle
.
addAttribute
(
new
Attribute
(
"separator"
,
","
));
keysEle
.
addElement
(
new
TextElement
(
"${column.
valu
e}"
));
keysEle
.
addElement
(
new
TextElement
(
"${column.
escapedColumnNam
e}"
));
XmlElement
otherwiseEle
=
new
XmlElement
(
"otherwise"
);
chooseEle
.
addElement
(
otherwiseEle
);
...
...
src/main/java/com/itfsw/mybatis/generator/plugins/SelectiveEnhancedPlugin.java
View file @
c2fe5274
...
...
@@ -397,7 +397,7 @@ public class SelectiveEnhancedPlugin extends BasePlugin implements IUpsertPlugin
insertForeachEle
.
addAttribute
(
new
Attribute
(
"open"
,
"("
));
insertForeachEle
.
addAttribute
(
new
Attribute
(
"separator"
,
","
));
insertForeachEle
.
addAttribute
(
new
Attribute
(
"close"
,
")"
));
insertForeachEle
.
addElement
(
new
TextElement
(
"${column.
valu
e}"
));
insertForeachEle
.
addElement
(
new
TextElement
(
"${column.
escapedColumnNam
e}"
));
insertWhenEle
.
addElement
(
insertForeachEle
);
XmlElement
insertOtherwiseEle
=
new
XmlElement
(
"otherwise"
);
...
...
@@ -483,13 +483,13 @@ public class SelectiveEnhancedPlugin extends BasePlugin implements IUpsertPlugin
Element
incrementEle
=
PluginTools
.
getHook
(
IIncrementsPluginHook
.
class
).
incrementSetsWithSelectiveEnhancedPluginElementGenerated
(
versionColumn
);
// 普通情况
if
(
incrementEle
==
null
&&
versionColumn
==
null
)
{
setForeachEle
.
addElement
(
new
TextElement
(
"${column.
valu
e} = #{record.${column.javaProperty},jdbcType=${column.jdbcType}}"
));
setForeachEle
.
addElement
(
new
TextElement
(
"${column.
escapedColumnNam
e} = #{record.${column.javaProperty},jdbcType=${column.jdbcType}}"
));
}
else
if
(
incrementEle
!=
null
)
{
setForeachEle
.
addElement
(
incrementEle
);
}
else
if
(
versionColumn
!=
null
)
{
XmlElement
ifEle
=
new
XmlElement
(
"if"
);
ifEle
.
addAttribute
(
new
Attribute
(
"test"
,
"column.value != '"
+
versionColumn
.
getActualColumnName
()
+
"'.toString()"
));
ifEle
.
addElement
(
new
TextElement
(
"${column.
valu
e} = #{record.${column.javaProperty},jdbcType=${column.jdbcType}}"
));
ifEle
.
addElement
(
new
TextElement
(
"${column.
escapedColumnNam
e} = #{record.${column.javaProperty},jdbcType=${column.jdbcType}}"
));
setForeachEle
.
addElement
(
ifEle
);
}
...
...
src/main/java/com/itfsw/mybatis/generator/plugins/UpsertPlugin.java
View file @
c2fe5274
...
...
@@ -295,7 +295,7 @@ public class UpsertPlugin extends BasePlugin {
foreachInsertColumns
.
addAttribute
(
new
Attribute
(
"collection"
,
"selective"
));
foreachInsertColumns
.
addAttribute
(
new
Attribute
(
"item"
,
"column"
));
foreachInsertColumns
.
addAttribute
(
new
Attribute
(
"separator"
,
","
));
foreachInsertColumns
.
addElement
(
new
TextElement
(
"${column.
valu
e}"
));
foreachInsertColumns
.
addElement
(
new
TextElement
(
"${column.
escapedColumnNam
e}"
));
insertEle
.
addElement
(
foreachInsertColumns
);
...
...
@@ -342,7 +342,7 @@ public class UpsertPlugin extends BasePlugin {
foreachSetColumns
.
addAttribute
(
new
Attribute
(
"collection"
,
"selective"
));
foreachSetColumns
.
addAttribute
(
new
Attribute
(
"item"
,
"column"
));
foreachSetColumns
.
addAttribute
(
new
Attribute
(
"separator"
,
","
));
foreachSetColumns
.
addElement
(
new
TextElement
(
"${column.
value} = values(${column.valu
e})"
));
foreachSetColumns
.
addElement
(
new
TextElement
(
"${column.
escapedColumnName} = values(${column.escapedColumnNam
e})"
));
document
.
getRootElement
().
addElement
(
insertEle
);
logger
.
debug
(
"itfsw(存在即更新插件):"
+
introspectedTable
.
getMyBatis3XmlMapperFileName
()
+
"增加batchUpsertSelective实现方法。"
);
...
...
src/test/java/com/itfsw/mybatis/generator/plugins/BugFixedTest.java
0 → 100644
View file @
c2fe5274
/*
* Copyright (c) 2018.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package
com
.
itfsw
.
mybatis
.
generator
.
plugins
;
import
com.itfsw.mybatis.generator.plugins.tools.*
;
import
org.apache.ibatis.session.SqlSession
;
import
org.junit.Assert
;
import
org.junit.Test
;
import
java.lang.reflect.Array
;
/**
* ---------------------------------------------------------------------------
*
* ---------------------------------------------------------------------------
* @author: hewei
* @time:2018/5/29 15:56
* ---------------------------------------------------------------------------
*/
public
class
BugFixedTest
{
/**
* 在使用 ModelColumnPlugin 插件时遇到关键词column或者table定义了alias属性,插件没有正确取值
*/
@Test
public
void
bug0001
()
throws
Exception
{
MyBatisGeneratorTool
tool
=
MyBatisGeneratorTool
.
create
(
"scripts/BugFixedTest/bug-0001.xml"
);
tool
.
generate
(()
->
DBHelper
.
createDB
(
"scripts/BugFixedTest/bug-0001.sql"
),
new
AbstractShellCallback
()
{
@Override
public
void
reloadProject
(
SqlSession
sqlSession
,
ClassLoader
loader
,
String
packagz
)
throws
Exception
{
ObjectUtil
tbMapper
=
new
ObjectUtil
(
sqlSession
.
getMapper
(
loader
.
loadClass
(
packagz
+
".TbMapper"
)));
ObjectUtil
tb
=
new
ObjectUtil
(
loader
,
packagz
+
".Tb"
);
tb
.
set
(
"id"
,
121L
);
tb
.
set
(
"inc"
,
"inc_001"
);
tb
.
set
(
"table"
,
"tb"
);
// selective
ObjectUtil
TbColumnId
=
new
ObjectUtil
(
loader
,
packagz
+
".Tb$Column#id"
);
ObjectUtil
TbColumnInc
=
new
ObjectUtil
(
loader
,
packagz
+
".Tb$Column#inc"
);
ObjectUtil
TbColumnTable
=
new
ObjectUtil
(
loader
,
packagz
+
".Tb$Column#table"
);
Object
columns
=
Array
.
newInstance
(
TbColumnInc
.
getCls
(),
3
);
Array
.
set
(
columns
,
0
,
TbColumnId
.
getObject
());
Array
.
set
(
columns
,
1
,
TbColumnInc
.
getObject
());
Array
.
set
(
columns
,
2
,
TbColumnTable
.
getObject
());
// sql
String
sql
=
SqlHelper
.
getFormatMapperSql
(
tbMapper
.
getObject
(),
"insertSelective"
,
tb
.
getObject
(),
columns
);
Assert
.
assertEquals
(
sql
,
"insert into tb ( id , field1 , `table` ) values ( 121 , 'inc_001' , 'tb' )"
);
Object
result
=
tbMapper
.
invoke
(
"insertSelective"
,
tb
.
getObject
(),
columns
);
Assert
.
assertEquals
(
result
,
1
);
}
});
}
}
src/test/resources/scripts/BugFixedTest/bug-0001.sql
0 → 100644
View file @
c2fe5274
/*
Navicat MySQL Data Transfer
Source Server : localhost
Source Server Version : 50617
Source Host : localhost:3306
Source Database : mybatis-generator-plugin
Target Server Type : MYSQL
Target Server Version : 50617
File Encoding : 65001
Date: 2017-06-27 11:17:08
*/
SET
FOREIGN_KEY_CHECKS
=
0
;
-- ----------------------------
-- Table structure for tb
-- ----------------------------
DROP
TABLE
IF
EXISTS
`tb`
;
CREATE
TABLE
`tb`
(
`id`
bigint
(
20
)
NOT
NULL
AUTO_INCREMENT
COMMENT
'注释1'
,
`field1`
varchar
(
255
)
DEFAULT
NULL
COMMENT
'注释2'
,
`field2`
int
DEFAULT
NULL
,
`table`
varchar
(
255
)
DEFAULT
NULL
,
PRIMARY
KEY
(
`id`
)
)
ENGINE
=
MyISAM
DEFAULT
CHARSET
=
utf8
;
\ No newline at end of file
src/test/resources/scripts/BugFixedTest/bug-0001.xml
0 → 100644
View file @
c2fe5274
<?xml version="1.0" encoding="UTF-8"?>
<!--
~ Copyright (c) 2018.
~
~ Licensed under the Apache License, Version 2.0 (the "License");
~ you may not use this file except in compliance with the License.
~ You may obtain a copy of the License at
~
~ http://www.apache.org/licenses/LICENSE-2.0
~
~ Unless required by applicable law or agreed to in writing, software
~ distributed under the License is distributed on an "AS IS" BASIS,
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
~ See the License for the specific language governing permissions and
~ limitations under the License.
-->
<!DOCTYPE generatorConfiguration
PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<properties
resource=
"db.properties"
/>
<!--导入属性配置 -->
<context
id=
"default"
targetRuntime=
"MyBatis3"
>
<property
name=
"autoDelimitKeywords"
value=
"true"
/>
<property
name=
"beginningDelimiter"
value=
"`"
/>
<property
name=
"endingDelimiter"
value=
"`"
/>
<!-- 插件 -->
<plugin
type=
"com.itfsw.mybatis.generator.plugins.SelectiveEnhancedPlugin"
/>
<plugin
type=
"com.itfsw.mybatis.generator.plugins.ModelColumnPlugin"
/>
<!--jdbc的数据库连接 -->
<jdbcConnection
driverClass=
"${driver}"
connectionURL=
"${url}"
userId=
"${username}"
password=
"${password}"
/>
<!-- Model模型生成器,用来生成含有主键key的类,记录类 以及查询Example类
targetPackage 指定生成的model生成所在的包名
targetProject 指定在该项目下所在的路径 -->
<javaModelGenerator
targetPackage=
""
targetProject=
""
>
<!-- 是否对model添加 构造函数 -->
<property
name=
"constructorBased"
value=
"true"
/>
<!-- 给Model添加一个父类 -->
<!--<property name="rootClass" value="com.itfsw.base"/>-->
</javaModelGenerator>
<!--Mapper映射文件生成所在的目录 为每一个数据库的表生成对应的SqlMap文件 -->
<sqlMapGenerator
targetPackage=
""
targetProject=
""
/>
<!-- 客户端代码,生成易于使用的针对Model对象和XML配置文件 的代码
type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper对象
type="MIXEDMAPPER",生成基于注解的Java Model 和相应的Mapper对象
type="XMLMAPPER",生成SQLMap XML文件和独立的Mapper接口 -->
<javaClientGenerator
targetPackage=
""
targetProject=
""
type=
"XMLMAPPER"
/>
<!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 要自动生成的表 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
<table
tableName=
"tb"
alias=
"Test"
>
<generatedKey
column=
"id"
sqlStatement=
"MySql"
identity=
"true"
/>
<columnOverride
column=
"field1"
property=
"inc"
/>
</table>
</context>
</generatorConfiguration>
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment