Mybatis上路_06-使用Java自动生成

11人收藏此文章, 我要收藏发表于1个月前(2013-04-24 23:05) , 已有151次阅读 ,共0个评论

1.编写Generator执行配置文件:

generatorConfigation.xml。注意配置数据库驱动包的绝对路径。

01 <?xml version="1.0" encoding="UTF-8"?>
02 <!DOCTYPE generatorConfiguration
03   PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
04   "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
05  
06 <generatorConfiguration>
07     <!-- 数据库驱动包,使用绝对路径 -->
08     <classPathEntry location="c:/mysql-connector-java-5.1.22-bin.jar" />
09   
10     <!-- 环境配置 **************************************************
11         id="自定义的配置名称"
12         targetRuntime="MyBatis版本" -->
13     <context id="MySqlTables" targetRuntime="MyBatis3" >
14     
15         <!-- 数据库  ===============================================
16             driverClass="驱动"
17             connectionURL="数据库url"
18             userId="用户"
19             password="密码" -->
20         <jdbcConnection
21             driverClass="com.mysql.jdbc.Driver"
22             connectionURL="jdbc:mysql://127.0.0.1:3306/db_mybatis" 
23             userId="root"
24             password="root">  
25         </jdbcConnection>
26  
27         <!-- Java数据类型分离器,数据类型转换 =====================
28             property 属性
29                 name="强迫双精度"
30                 value="不" -->
31         <javaTypeResolver>
32             <property name="forceBigDecimals" value="false" />
33         </javaTypeResolver>
34   
35         <!-- Java模型生成器 =======================================
36             targetPackage="生成文件的目标路径"
37             targetProject="已存在的项目包"
38                 enableSubPackages-可以省略对应约束名,true-是的,可以省略tb_generator
39                 trimString-验证字符串,true-是的 -->
40         <javaModelGenerator
41                 targetPackage="cn.cvu.test.model"
42                 targetProject="src">
43             <property name="enableSubPackages" value="false" />
44             <property name="trimStrings" value="true" />
45         </javaModelGenerator>
46   
47         <!-- sql映射文件生成器 =======================================
48             targetPackage="生成文件的目标路径"
49             targetProject="已存在的项目包"
50                 enableSubPackages-可以省略对应约束名,true-是的,可以省略tb_generator -->
51         <sqlMapGenerator
52                 targetPackage="cn.cvu.test.xml"
53                 targetProject="src">
54             <property name="enableSubPackages" value="false" />
55         </sqlMapGenerator>
56   
57         <!-- java委托对象DAO生成器,接口 =============================
58             type=""
59             targetPackage="生成文件的目标路径"
60             targetProject="已存在的项目包"
61                 enableSubPackages-可以省略对应约束名,true-是的,可以省略tb_generator -->
62         <javaClientGenerator
63                 type="XMLMAPPER"
64                 targetPackage="cn.cvu.test.dao"
65                 targetProject="src">
66             <property name="enableSubPackages" value="false" />
67         </javaClientGenerator>
68         
69         <!-- 表单,已存在,根据此表生成其它文件 =======================
70             tableName="已有的表单名称"
71             domainObjetctName="对应生成的文件名前缀" -->
72         <table tableName="tb_generator" domainObjectName="Eminem">
73             <!-- useActualColumnNames-使用真实列名 ,
74                  true-嗯。如果false,则由columnOverride节点控制  -->
75             <property name="useActualColumnNames" value="true" />
76             
77             <!-- 标识列
78                 column="列名" sqlStatement="某种数据库语言" identity="作为主键" -->
79             <generatedKey column="id" sqlStatement="MySql" identity="true" />
80             
81             <!-- 覆盖项,当property name="useActualColumnNames" value="true"时。
82                 column="被覆盖值的列名" property="用来覆盖的对应的java类的属性" -->
83             <columnOverride column="name" property="generName" />
84   
85         </table>
86         
87     </context>
88  
89 </generatorConfiguration>

2.在MyEclipse中建空web项目:

将配置文件放到src里。加入generator的jar文件。

3.编写并执行Java程序:

01 package cn.cvu.test.build;
02   
03 import java.io.File;
04 import java.util.ArrayList;
05 import java.util.List;
06 import org.junit.Test;
07 import org.mybatis.generator.api.MyBatisGenerator;
08 import org.mybatis.generator.config.Configuration;
09 import org.mybatis.generator.config.xml.ConfigurationParser;
10 import org.mybatis.generator.internal.DefaultShellCallback;
11   
12 public class TestGenerateWithJava {
13   
14     @Test
15     public void testBuild() throws Exception {
16                 // 信息缓存
17                 List<String> warnings = new ArrayList<String>();
18                 // 覆盖已有的重名文件
19                 boolean overwrite = true;
20                 // 准备 配置文件
21                 File configFile = new File("F:/myeclipse_workspace/generator/src/generatorConfigation.xml");
22                 // 1.创建 配置解析器
23                 ConfigurationParser parser = new ConfigurationParser(warnings);
24                 // 2.获取 配置信息
25                 Configuration config = parser.parseConfiguration(configFile);
26                 // 3.创建 默认命令解释调回器
27                 DefaultShellCallback callback = new DefaultShellCallback(overwrite);
28                 // 4.创建 mybatis的生成器
29                 MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
30                 // 5.执行,关闭生成器
31         myBatisGenerator.generate(null);
32     }
33 }

4.查看并修改生成的文件:

选中src,按F5刷新,可以看到新文件已经创建:

修改报错的EmineMapper.java文件,去除注解:

5.测试,使用生成的文件查询:

1)导入MyBatis的jar包:

mybatis-3.2.2.jar 
                mybatis-generator-core-1.3.2.jar 
                mysql-connector-java-5.1.22-bin.jar

2)创建MyBatis的xml配置文件:

上面我们注释掉了自动生成的注解代码,在src新建一个xml配置文件,mybatisConfigation.xml:

01 <?xml version="1.0" encoding="UTF-8" ?>
02 <!DOCTYPE configuration
03    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
04     "http://mybatis.org/dtd/mybatis-3-config.dtd">
05  
06 <configuration>
07     <environments default="development">
08         <environment id="development">
09             <transactionManager type="JDBC" />
10             <dataSource type="POOLED">
11                 <property name="driver" value="com.mysql.jdbc.Driver" />
12                 <property name="url" value="jdbc:mysql://127.0.0.1:3306/db_mybatis" />
13                 <property name="username" value="root" />
14                 <property name="password" value="root" />
15             </dataSource>
16         </environment>
17     </environments>
18  
19     <mappers>
20         <!-- 引入MBG生成器创建的映射文件 -->
21         <mapper resource="cn/cvu/test/xml/EminemMapper.xml" />
22     </mappers>
23 </configuration>

3)Java测试代码:

创建测试类cn.cvu.test.dotest.TestDoGeneratorWithJava :

01 package cn.cvu.test.dotest;
02  
03 import java.io.Reader;
04 import java.util.List;
05 import org.apache.ibatis.io.Resources;
06 import org.apache.ibatis.session.SqlSession;
07 import org.apache.ibatis.session.SqlSessionFactoryBuilder;
08 import org.junit.Test;
09 import cn.cvu.test.dao.EminemMapper;
10 import cn.cvu.test.model.Eminem;
11 import cn.cvu.test.model.EminemExample;
12 import cn.cvu.test.model.EminemExample.Criteria;
13  
14 public class TestDoGeneratorWithJava {
15  
16     @Test
17     public void testQuery() throws Exception {
18  
19         // 创建SQL会话:
20         Reader reader = Resources.getResourceAsReader("mybatisConfigation.xml");
21         SqlSession session = new SqlSessionFactoryBuilder().build(reader).openSession();
22  
23         // 创建查询实例:
24         EminemExample eminemExample = new EminemExample();
25  
26         // 获取映射实体:
27         EminemMapper mapper = session.getMapper(EminemMapper.class);
28  
29         // 利用实体通过实例查询全部条目
30         List<Eminem> eminems = mapper.selectByExample(eminemExample);
31         System.out.println("ID \t\t name \t\t notes \n");
32         for (Eminem eminem : eminems) {
33                 System.out.println(eminem.getId()+
34                                 "\t\t"+eminem.getGenerName()+
35                                 "\t\t"+eminem.getNotes());
36         }
37         session.close();
38     }
39 }

- end

Mybatis上路_06-使用Java自动生成[转]的更多相关文章

  1. Mybatis上路_06-使用Java自动生成

    目录[-] 1.编写Generator执行配置文件: 2.在MyEclipse中建空web项目: 3.编写并执行Java程序: 4.查看并修改生成的文件: 5.测试,使用生成的文件查询: 1)导入My ...

  2. MyBatis Generator作为maven插件自动生成增删改查代码及配置文件例子

    什么是MyBatis Generator MyBatis Generator (MBG) 是一个Mybatis的代码生成器,可以自动生成一些简单的CRUD(插入,查询,更新,删除)操作代码,model ...

  3. JAVA自动生成正则表达式工具类

    经过很久的努力,终于完成了JAVA自动生成正则表达式工具类.还记得之前需要正则,老是从网上找吗?找了想修改也不会修改.现在不用再为此烦恼了,使用此生成类轻松搞定所有正则表达式.赶快在同事面前炫一下吧. ...

  4. 使用MyBatis Generator 1.3.7自动生成代码

    MyBatis Generator是一款mybatis自动代码生成工具,可以通过配置后自动生成文件. MyBatis Generator有几种方法可以生成代码,下面是其中一种.  一.官网下载 MyB ...

  5. mybatis多表查询,自动生成id

    主要是在配置文件中,配置好所要包含的字段. 类关系:account----role,1对1 account包含role类 java类: public class Account{ private In ...

  6. java自动生成entity文件

    网上关于自动生成entity文件的代码很多,看了很多代码后,在先辈们的基础上再完善一些功能(指定多个表,全部表). 为了使用方便所以把两个类写在一个java文件中,所以大家可以直接拿这个java文件, ...

  7. mybatis根据数据库表结构自动生成实体类,dao,mapper

    首先, pom需要引入 <!-- mysql --> <dependency> <groupId>mysql</groupId> <artifac ...

  8. java自动生成代码

    看到这个标题,如果你以为真的可以完全自动生成,那你就太Naive啦 我这里想介绍的是,利用模板生成我们需要的代码 一.模板 首先来说说模板,常见的java模板有:FreeMarker.Velocity ...

  9. java自动生成表单简单实例

    数据库表设置 tb_form(form表单) 字段 类型 约束 说明 Id Int 主键 主键 Formid Varchar2(20) 唯一 Form表单id的值 Action Varchar2(20 ...

随机推荐

  1. Android学习笔记27:网格视图GridView的使用

    网格视图GridView的排列方式与矩阵类似,当屏幕上有很多元素(文字.图片或其他元素)需要按矩阵格式进行显示时,就可以使用GridView控件来实现. 本文将以一个具体的实例来说明如何使用GridV ...

  2. MFC 全部自绘控件 界面库

    http://download.csdn.net/detail/q97082645/8160793 http://download.csdn.net/user/q97082645/uploads/3

  3. C#/ASP.NET应用程序配置文件app.config/web.config的增、删、改操作

    原文 http://www.cnblogs.com/codealone/archive/2013/09/22/3332607.html 应用程序配置文件,对于asp.net是 web.config,对 ...

  4. boost库在工作(40)串行通讯

    现代的计算机技术进步很快,各种的通讯也日新月异,像USB.网络.蓝牙.WIFI等通讯技术飞速地出现,改变了整个计算机的通讯能力,速度已经达到GBit级别.但是有一种最原始的通讯方式,还是保留了30年, ...

  5. uvalive5810 uva12368 Candles

    题意:每组数据给出n个数,每个数在1-100,问组成这些数的蜡烛的权值的最小值.权值=把选的蜡烛从大到小排列组成的数 组成方式:比如有1 3两个蜡烛 可以组成13(1和3)或4(1+3) 只有一个加号 ...

  6. Linux-storage-stack-diagram

    just a diagram 一目了然. 对于isci 只是用过LIO和STGT 两种后端. 这里有各种后端的比较. http://scst.sourceforge.net/comparison.ht ...

  7. poj 2540 Hotter Colder 切割多边形

    /* poj 2540 Hotter Colder 切割多边形 用两点的中垂线切割多边形,根据冷热来判断要哪一半 然后输出面积 */ #include <stdio.h> #include ...

  8. javascript第一课javascript:void(0);

    在一些需要使用<a href="#"></a>的地方,把#号换成javascript:void(0); 可以防止在链接跳转到新页面,void(0)放里面的参 ...

  9. MySQL数据处理函数

    数据处理函数 有时从数据库表中获取到的数据须要进行一些处理. 如将小写字母替换为对应的大写字母.这个处理过程能够在客户机上进行.也能够在数据库上进行. 数据库上进行会更高效.数据库中有对应的数据处理函 ...

  10. 【分享】事实上,你VS界面也可以如此,VS界面美化

    阿土.它直接在地图上. 第一节目:Transformers(变形金刚) 第二方案:Assassin's Creed (刺客信条) watermark/2/text/aHR0cDovL2Jsb2cuY3 ...