MyBatis GeneratorXML Configuration File Reference
In the most common use case, MyBatis Generator (MBG) is driven by an XML configuration file. The configuration file tells MBG:
- How to connect to the database
- What objects to generate, and how to generate them
- What tables should be used for object generation
The following is an example MBG configuration file. See the individual pages for each element for more information about the elements and the values of the attributes.
<?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 location="/Program Files/IBM/SQLLIB/java/db2java.zip" /> <context id="DB2Tables" targetRuntime="MyBatis3"> <jdbcConnection driverClass="COM.ibm.db2.jdbc.app.DB2Driver" connectionURL="jdbc:db2:TEST" userId="db2admin" password="db2admin"> </jdbcConnection> <javaTypeResolver > <property name="forceBigDecimals" value="false" /> </javaTypeResolver> <javaModelGenerator targetPackage="test.model" targetProject="\MBGTestProject\src"> <property name="enableSubPackages" value="true" /> <property name="trimStrings" value="true" /> </javaModelGenerator> <sqlMapGenerator targetPackage="test.xml" targetProject="\MBGTestProject\src"> <property name="enableSubPackages" value="true" /> </sqlMapGenerator> <javaClientGenerator type="XMLMAPPER" targetPackage="test.dao" targetProject="\MBGTestProject\src"> <property name="enableSubPackages" value="true" /> </javaClientGenerator> <table schema="DB2ADMIN" tableName="ALLTYPES" domainObjectName="Customer" > <property name="useActualColumnNames" value="true"/> <generatedKey column="ID" sqlStatement="DB2" identity="true" /> <columnOverride column="DATE_FIELD" property="startDate" /> <ignoreColumn column="FRED" /> <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> </table> </context> </generatorConfiguration>
Important notes about this file follow:
- The file specifies that the legacy DB2 CLI driver will be used to connect to the database, and also specifies where the driver can be found.
- The Java Type Resolver should not force the use of BigDecimal fields - this means that integral types (Short, Integer, Long, etc.) will be substituted if possible. This feature is an attempt to make database DECIMAL and NUMERIC columns easier to deal with.
- The Java model generator should use sub-packages. This means that the generated model
objects will be placed in a package called
test.model.db2admin
in this case (because the table is in the DB2ADMIN schema). If theenableSubPackages
attribute was set tofalse
, then the package would betest.model
. The Java model generator should also trim strings. This means that the setters for any String properties will call thetrim
function - this is useful if your database might return blank characters at the end of character columns. - The SQL Map generator should use sub-packages. This means that the generated XML files
will be placed in a package called
test.xml.db2admin
in this case (because the table is in the DB2ADMIN schema). If theenableSubPackages
attribute was set tofalse
, then the package would betest.xml
. - The DAO generator should use sub-packages. This means that the generated DAO classes
will be placed in a package called
test.dao.db2admin
in this case (because the table is in the DB2ADMIN schema). If theenableSubPackages
attribute was set tofalse
, then the package would betest.dao
. The DAO generator should generate mapper interfaces that reference an XML configuration for MyBatis. - The file specifies only one table will be introspected, but many more could be specified.
Important notes about the specified table include:
- The generated objects will be based on the name Customer (
CustomerKey
,Customer
,CustomerMapper
, etc.) - rather than on the table name. - Actual column names will be used as properties. If this property were set to
false
(or not specified), then MBG would attempt to camel case the column names. In either case, the name can be overridden by the<columnOverride>
element - The column has a generated key, it is an identity column, and the database type is DB2.
This will cause
MBG to generate the proper
<selectKey>
element in the generated<insert>
statement so that the newly generated key can be returned (using DB2 specific SQL). - The column
DATE_FIELD
will be mapped to a property calledstartDate
. This will override the default property which would beDATE_FIELD
in this case, ordateField
if theuseActualColumnNames
property was set tofalse
. - The column
FRED
will be ignored. No SQL will list the field, and no Java property will be generated. - The column
LONG_VARCHAR_FIELD
will be treated as aVARCHAR
field, regardless of the actual data type.
- The generated objects will be based on the name Customer (