The <javaClientGenerator> Element
The <javaClientGenerator> element is used to define properties of the Java client generator. The Java client Generator builds Java interfaces and classes that allow easy use of the generated Java model and XML map files. For iBATIS2 target environments, these generated objects take the form of DAO interface and implementation classes. For MyBatis, the generated objects take the form of mapper interfaces. This element is a optional child element of the <context> element. If you do not specify this element, then MyBatis Generator (MBG) will not generate Java client interfaces and classes.
Required Attributes
Attribute | Description | ||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
type | This attribute is used to select one of the predefined Java Client generators, or
to specify a user provided Java Client generator.
Any user provided DAO generator must extend the class
org.mybatis.generator.codegen.AbstractJavaClientGenerator
class, and must have a public default constructor.
The attribute accepts the following values for selecting one of the predefined generators:
|
||||||||||||||||||||||||
targetPackage | This is the package where the generated interfaces and implementation classes
will be placed. In
the default generators, the property "enableSubPackages"
controls how the actual package is calculated. If true,
then the calculated package will be the targetPackage plus
sub packages for the table's catalog and schema if they exist.
If "enableSubPackages" is false (the default) then the calculated package will be
exactly what is specified in the targetPackage attribute.
MBG will create folders as required for the generated
packages.
Note: the package for implementation classes may be overridden by specifying the optional implementationPackage attribute as shown below. |
||||||||||||||||||||||||
targetProject | This is used to specify a target project for the generated interfaces and classes. When running in the Eclipse environment, this specifies the project and source folder where the objects will be saved. In other environments, this value should be an existing directory on the local file system. MBG will not create this directory if it does not exist. |
Optional Attributes
Attribute | Description |
---|---|
implementationPackage | If specified, implementation classes will be placed in this package. In the default generators, the property "enableSubPackages" controls how the actual package is calculated. If true, then the calculated package will be the implementationPackage plus sub packages for the table's catalog and schema if they exist. If "enableSubPackages" is false (the default) then the calculated package will be exactly what is specified in the implementationPackage attribute. MBG will create folders as required for the generated packages. |
Child Elements
- <property> (0..N)
Supported Properties
This table lists the properties of the default SQL Map generators that can be specified with the <property> child element:
Property Name | Property Values | ||||||||
---|---|---|---|---|---|---|---|---|---|
enableSubPackages | This property is used to select whether MBG will generate different
Java packages for the objects based on the catalog and schema of the
introspected table.
For example, suppose a table MYTABLE in schema MYSCHMA. Also suppose that the targetPackage attribute is set to "com.mycompany". If this property is true, the generated DAO interface and class for the table will be placed in the package "com.mycompany.myschema". If the property is false, the generated SQL Map will be placed in the "com.mycompany" schema. The default value is false. |
||||||||
exampleMethodVisibility | This property is used to set the visibility of the different "ByExample"
methods - selectByExample, deleteByExample, etc. If not specified, the
methods will be public and will be declared in the interface.
This property allows you to hide these methods if you only want to use them
to implement other specialized methods.
Important note: this property is ignored if the target runtime is MyBatis3. |
||||||||
methodNameCalculator | This property is used to select a method name calculator. A method name
calculator can be used to provide different names for the DAO methods.
You can select one of the predefined values, or you can specify the
fully qualified name of a class that implements the
org.mybatis.generator.api.DAOMethodNameCalculator interface
if neither of the supplied options are appropriate in your environment.
Important note: this property is ignored if the target runtime is MyBatis3. |
||||||||
rootInterface | This property can be used to specify a super interface for all generated
interface objects. This value may be overridden by specifying
the rootInterface property on a Table configuration.
Important: MBG does not verify that the interface exists, or is a valid Java interface. If specified, the value of this property should be a fully qualified interface name (like com.mycompany.MyRootInterface). |
Example
This element specifies that we always want to place generated interfaces and objects in the "'test.model" package and that we want to use subpackages based on the table schema and catalog. It also specifies that we want to generate mapper interfaces that reference an XML configuration file for MyBatis3.
<javaClientGenerator targetPackage="test.model" targetProject="\MyProject\src" type="XMLMAPPER"> <property name="enableSubPackages" value="true" /> </javaClientGenerator>