http://my.oschina.net/vigiles/blog/125127
Mybatis上路_05-使用命令行自动生成
1人收藏此文章,
我要收藏 发表于1个月前(2013-04-24 22:22) , 已有
25次阅读 ,共
0个评论
1.数据准备:
mysql5.5 。
1)建库:
1 |
CREATE DATABASE DB_MYBATIS CHAR SET UTF8; |
2)建表:
1 |
CREATE TABLE TB_GENERATOR( |
2 |
id INT PRIMARY KEY AUTO_INCREMENT, |
3)预设数据:
1 |
INSERT INTO TB_GENERATOR VALUES (1, "eminem1", "notes1"); |
2 |
INSERT INTO TB_GENERATOR VALUES (2, "eminem2", "notes2"); |
2.编写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"> |
06 |
<generatorConfiguration> |
08 |
<classPathEntry location="mysql-connector-java-5.1.22-bin.jar" /> |
10 |
<!-- 环境配置 ************************************************** |
12 |
targetRuntime="MyBatis版本" --> |
13 |
<context id="MySqlTables" targetRuntime="MyBatis3" > |
15 |
<!-- 数据库 =============================================== |
17 |
connectionURL="数据库url" |
21 |
driverClass="com.mysql.jdbc.Driver" |
22 |
connectionURL="jdbc:mysql://127.0.0.1:3306/db_mybatis" |
27 |
<!-- Java数据类型分离器,数据类型转换 ===================== |
32 |
<property name="forceBigDecimals" value="false" /> |
35 |
<!-- Java模型生成器 ======================================= |
36 |
targetPackage="生成文件的目标路径" |
37 |
targetProject="已存在的项目包" |
38 |
enableSubPackages-可以省略对应约束名,true-是的,可以省略tb_generator |
39 |
trimString-验证字符串,true-是的 --> |
41 |
targetPackage="test.model" |
42 |
targetProject="\cn\cvu"> |
43 |
<property name="enableSubPackages" value="false" /> |
44 |
<property name="trimStrings" value="true" /> |
47 |
<!-- sql映射文件生成器 ======================================= |
48 |
targetPackage="生成文件的目标路径" |
49 |
targetProject="已存在的项目包" |
50 |
enableSubPackages-可以省略对应约束名,true-是的,可以省略tb_generator --> |
52 |
targetPackage="test.xml" |
53 |
targetProject="\cn\cvu"> |
54 |
<property name="enableSubPackages" value="false" /> |
57 |
<!-- java委托对象DAO生成器,接口 ============================= |
59 |
targetPackage="生成文件的目标路径" |
60 |
targetProject="已存在的项目包" |
61 |
enableSubPackages-可以省略对应约束名,true-是的,可以省略tb_generator --> |
64 |
targetPackage="test.dao" |
65 |
targetProject="\cn\cvu"> |
66 |
<property name="enableSubPackages" value="false" /> |
67 |
</javaClientGenerator> |
69 |
<!-- 表单,已存在,根据此表生成其它文件 ======================= |
71 |
domainObjetctName="对应生成的文件名前缀" --> |
72 |
<table tableName="tb_generator" domainObjectName="Eminem"> |
73 |
<!-- useActualColumnNames-使用真实列名 , |
74 |
true-嗯。如果false,则由columnOverride节点控制 --> |
75 |
<property name="useActualColumnNames" value="true" /> |
78 |
column="列名" sqlStatement="某种数据库语言" identity="作为主键" --> |
79 |
<generatedKey column="id" sqlStatement="MySql" identity="true" /> |
81 |
<!-- 覆盖项,当上面的property name="useActualColumnNames" value="true"时。 |
82 |
column="被覆盖值的列名" property="用来覆盖的对应的java类的属性" --> |
83 |
<columnOverride column="name" property="generName" /> |
88 |
</generatorConfiguration> |
3.搭建执行环境:
1)创建项目包:

2)准备文件:

4.执行命令行语句:
C:\> java -jar mybatis-generator-core-1.3.2.jar -configfile generatorConfigation.xml

如果增加“ -overwrite”参数会覆盖原有文件。事实上原有文件会被重命名。


5.查看生成的文件:

6.查看文件内容:
在MyEclipse中新建空web项目,将“cn”包放入“src”内。

1) cn/cvu/dao/EminemMapper.java :
(1)修改自动生成的包路径。如果没有注解类包,可以注释图中第4行代码。

(2)然后将图中两行代码中的注解删除。
2)cn/cvu/model/Eminem.java :
修改包路径。

3) cn/cvu/model/EminemExample.java :
修改包路径。

4)cn/cvu/xml/EminemMapper.xml :
修改映射文件路径:







7.测试,使用生成的文件查询:
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"> |
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" /> |
21 |
<!-- 引入MBG生成器创建的映射文件 --> |
22 |
<mapper resource="cn/cvu/test/xml/EminemMapper.xml" /> |
3)Java测试代码:
创建测试类cn.cvu.test.dotest.TestGenerateWithXML :

01 |
package cn.cvu.test.dotest; |
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; |
14 |
public class TestGenerateWithXML { |
17 |
public void testQuery() throws Exception { |
20 |
Reader reader = Resources.getResourceAsReader("mybatisConfigation.xml"); |
21 |
SqlSession session = new SqlSessionFactoryBuilder().build(reader).openSession(); |
24 |
EminemExample eminemExample = new EminemExample(); |
27 |
EminemMapper mapper = session.getMapper(EminemMapper.class); |
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()); |

- end
- Mybatis上路_05-使用命令行自动生成
http://my.oschina.net/vigiles/blog/125127 目录[-] 1.数据准备: 1)建库: 2)建表: 3)预设数据: 2.编写Generator执行配置文件: 3.搭 ...
- JMeter命令行执行+生成HTML报告
1.为什么用命令行模式 使用GUI方式启动jmeter,运行线程较多的测试时,会造成内存和CPU的大量消耗,导致客户机卡死: 所以一般采用的方式是在GUI模式下调整测试脚本,再用命令行模式执行: 命令 ...
- mybatis框架下使用generator插件自动生成domain/mapping/mapper
手动去创建domain/mapping/mapper费时费力还容易出错,用插件自动生成非常的方便. 这里以MySQL数据库为例,也可以改成Oracle,改成相应的驱动和URL即可. 下载generat ...
- mybatis用mybatis-generator-core-1.3.5.jar自动生成实体类
原文出处:https://blog.csdn.net/shuoshuo_12345/article/details/80626241,本文只是个人总结而已! 方法1:在pom文件中添加依赖 只需在搭建 ...
- mybatis自定义代码生成器(Generator)——自动生成model&dao代码
花了两天的时间研究了下mybatis的generator大体了解了其生成原理以及实现过程.感觉generator做的非常不错,给开发者也留足了空间.看完之后在generator的基础上实现了自定义的生 ...
- InnoSetup 以命令行自动编译打包
本章介绍,在新建Innosetup的编译脚本iss文件后,在不运行Innosetup软件的基础上,以bat自动编译运行打包. 一.添加Innosetup软件包 下载InnoSetup软件包并解压到bu ...
- 7z 命令行方式生成自解压exe
一.下载 7z是一个免费的工具,除了通过命令行的方式提供各种文件.压缩包相关的操作外,还提供了一种方式可以打出自解压的exe程序.该程序从运行到结束经历了三个流程: (1) 解压文件到用户临时目录: ...
- 『动善时』JMeter基础 — 56、JMeter使用命令行模式生成HTML测试报告
目录 1.自动生成HTML图形化报告 2.使用已有的测试结果文件生成HTML报告 3.HTML图形化报告内容详解 (1)Dashboard页面:(重点查看) (2)Charts页面:(辅助分析) 4. ...
- 在GNU/Linux下使用命令行自动挂载与卸载USB磁盘
在命令行环境下如果每次都是靠手动敲入mount与umount命令来挂载与卸载USB磁盘是件很麻烦的事情.尤其是mount命令的参数非常多.比如,磁盘的分区类型(vfat.ntfs等),挂载的目录节点, ...
随机推荐
- [LeetCode]题解(python):150-Evaluate Reverse Polish Notation
题目来源: https://leetcode.com/problems/evaluate-reverse-polish-notation/ 题意分析: 给定一个数组,用这个数组来表示加减乘除,例如 [ ...
- asp.net mvc 不找其他view模板,只找cshtml
asp.net mvc 默认找view文件时,依次找后辍名为aspx.ascx.cshtml.vbhtml的view文件.但是项目住住用C#+Razor开发,这样找,岂不有性能损失. 添加以下代码: ...
- Oracle EBS-SQL (GL-2):从总帐追溯到库存
SELECT je_header_id,je_line_num,trx_class_name, trx_type_name, trx_number_displayed, trx_date, comme ...
- Microsoft Azure 大计算 – 宣布收购 GreenButton
数据以及令人不可思议的计算能力,正在改变我们日常业务的经营方式,从科学和工程到媒体和金融,各行各业的客户正逐渐意识到什么是可能的.我们对整个基因组进行分析,以研制新药物.我们构建金融和保险模型, ...
- [Leetcode][Python]25: Reverse Nodes in k-Group
# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 25: Reverse Nodes in k-Grouphttps://oj. ...
- poj1969---找规律
题意:按照s型分别给数编号,给 #include <stdio.h> #include <stdlib.h> int main() { int n; while(scanf(& ...
- 1.Solution的Build、Rebuild和Clean
大家好,我是原文,这篇随笔是对原文的翻译以及自己的体会. 做程序员没追求的话是永远找不到女朋友的,当然有追求也找不到,这个先不提,好在有追求的时候我是充实而且开心的.现在我们的问题是,每天调试项目,在 ...
- 算法精解(C语言描述) 第5章 读书笔记
第5章 5.1 单链表 /* -------------------------------- list.h -------------------------------- */ #ifndef L ...
- 前端新人学习笔记-------html/css/js基础知识点
即将毕业的软件工程大学生一枚,秋季招聘应聘的是Android,今年来到公司实习,要求做前端开发,所以一切只有现学,现在根据视频来学习,然后开这个博客记录一下自己的学习过程,废话不多说,开写. 4月6日 ...
- html 中的name,id ,value,class,list 作用与区别
name: 单独一个网页中,一个控件是否设置name不会影响这个网页功能的实现.当我们需要把这个控件 所关联的数据传递到数据库时,就必须设置name属性,否则这个值是没办法传到服务器保存的: id: ...