Hello Mybatis 02 mybatis generator
接着上一篇文章通过Mybatis完成了一个User的CRUD的功能之后,这篇开始还需要建立一个Blog类,这样就可以模拟一个简单的微博平台的数据库了。
数据库准备
首先我们,还是需要在数据库中新建一个表blog
CREATE TABLE `blog`.`blog` (
`b_id` INT NOT NULL,
`b_title` VARCHAR(45) NULL,
`b_content` VARCHAR(255) NULL,
`user_id` INT NULL,
PRIMARY KEY (`b_id`),
INDEX `fk_blog_user_idx` (`user_id` ASC),
CONSTRAINT `fk_blog_user`
FOREIGN KEY (`user_id`)
REFERENCES `blog`.`user` (`id`)
ON DELETE NO ACTION
ON UPDATE NO ACTION);
接下来,Oh~不,难道又要写一堆的xml和方法才能折腾完CRUD吗?这当然是我这种懒人不喜欢干的。还好mybatis提供了一个代码生成器mybatis generator工具。
可以去github的mybatis generator主页上下载这个工具
https://github.com/mybatis/generator/releases
我使用的是生成器版本是1.3.2
配置文件
接着只需要一个配置generator文件我们就能让上一篇里写个半死的东西全部自动生成出来了。
<?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>
<!-- 配置mysql 驱动jar包路径.用了绝对路径 -->
<classPathEntry location="/home/whthomas/software/javaframework/mysql-connector-java-5.1.30/mysql-connector-java-5.1.30-bin.jar" />
<context id="mysql_tables" targetRuntime="MyBatis3">
<!--<plugin type="pro.plugin.PaginationPlugin" />
为了防止生成的代码中有很多注释,比较难看,加入下面的配置控制 -->
<commentGenerator>
<property name="suppressAllComments" value="true" />
<property name="suppressDate" value="true" />
</commentGenerator>
<!-- 注释控制完毕 --> <!-- 数据库连接 -->
<jdbcConnection driverClass="org.gjt.mm.mysql.Driver"
connectionURL="jdbc:mysql://127.0.0.1:3306/blog"
userId="mybatis"
password="mybatis">
</jdbcConnection>
<javaTypeResolver >
<property name="forceBigDecimals" value="false" />
</javaTypeResolver> <!-- 数据表对应的model 层 -->
<javaModelGenerator targetPackage="pro.app.model" targetProject="../src">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator> <!-- sql mapper 映射配置文件 -->
<sqlMapGenerator targetPackage="pro.app.mapper" targetProject="../src">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator> <!-- 在ibatis2 中是dao层,但在mybatis3中,其实就是mapper接口 -->
<javaClientGenerator type="XMLMAPPER" targetPackage="pro.app.inter" targetProject="../src">
<property name="enableSubPackages" value="true" />
</javaClientGenerator> <!-- 要对那些数据表进行生成操作,必须要有一个. -->
<table schema="blog" tableName="blog"
enableCountByExample="false" enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false"
selectByExampleQueryId="false">
<generatedKey column="b_id" sqlStatement="MySql" identity="true"/>
</table> </context>
</generatorConfiguration>
mybatis generator可以生成三种类型的文件:vo类、Dao接口层和Mapper.xml文件,通过这个配置文件告诉generator你需要生成哪一些需要的文件。
在命令行界面输入
java -jar mybatis-generator-core-1.3..jar -configfile generatorConfig.xml -overwrite
这里的 -jar 和 -configfile 后面都是可以跟随相对路径的。输入这条命令之后,包括vo类、dao接口和mapper.xml文件全部都生成好了。整个人都好起来了。
新建一个BlogTest类,来测试一下生成的代码好不好用!
package pro.test; import java.io.Reader; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; import pro.app.inter.BlogMapper;
import pro.app.model.Blog; public class BlogTest {
private static SqlSessionFactory sqlSessionFactory;
private static Reader reader;
static{
try{
reader= Resources.getResourceAsReader("Configuration.xml");
sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
}catch(Exception e){
e.printStackTrace();
}
}
public static SqlSessionFactory getSession(){
return sqlSessionFactory;
}
public static void main(String[] args) {
SqlSession session = sqlSessionFactory.openSession();
try {
BlogMapper blogDAO = session.getMapper(BlogMapper.class);
//生成一个Blog实例
Blog blog=new Blog();
blog.setbTitle("Mybatis");
blog.setbContent("Mybatis is good! ");
blog.setUserId(1);
//新增一条Blog记录到数据库
blogDAO.insert(blog);
//从数据库选取刚刚的那一条Blog
Blog record=blogDAO.selectByPrimaryKey(1);
System.out.println(record.getbTitle());
System.out.println(record.getbContent());
//修改数据并保存
blog.setbTitle("mybatis update");
blogDAO.updateByPrimaryKey(blog);
//删除数据
blogDAO.deleteByPrimaryKey(1);
} finally {
session.close();
}
}
}
控制台输出:
Mybatis
Mybatis is good!
ok,没有报错。CRUD全部都搞定!省去了不少时间,设想如果有很多表使用这个工具可以节约多少的时间哇~当然复杂的sql语句还是要自己完成的。
总结
使用mybatis generator完成基本的CRUD配置。
Hello Mybatis 02 mybatis generator的更多相关文章
- springboot集成mybatis及mybatis generator工具使用
原文链接 前言mybatis是一个半自动化的orm框架,所谓半自动化就是mybaitis只支持数据库查出的数据映射到pojo类上,而实体到数据库的映射需要自己编写sql语句实现,相较于hibernat ...
- springboot入门(三)-- springboot集成mybatis及mybatis generator工具使用
前言 mybatis是一个半自动化的orm框架,所谓半自动化就是mybaitis只支持数据库查出的数据映射到pojo类上,而实体到数据库的映射需要自己编写sql语句实现,相较于hibernate这种完 ...
- spring boot集成mybatis(3) - mybatis generator 配置
Spring Boot 集成教程 Spring Boot 介绍 Spring Boot 开发环境搭建(Eclipse) Spring Boot Hello World (restful接口)例子 sp ...
- 03 Mybatis:01.Mybatis课程介绍及环境搭建&&02.Mybatis入门案例
mybatis框架共四天第一天:mybatis入门 mybatis的概述 mybatis的环境搭建 mybatis入门案例 -------------------------------------- ...
- 【mybatis】mybaits generator 逆向工程的使用
mybatis逆向工程官方网站:http://www.mybatis.org/generator/quickstart.html 准备xml文件.如下generator.xml全部内容 <?xm ...
- spring boot 尚桂谷学习笔记10 数据访问02 mybatis
数据访问 mybatis 创建一个 springboot 工程,模块选择 sql 中 mysql(数据驱动), jdbc(自动配置数据源), mybatis Web模块中选择 web pom 引入: ...
- mybatis 05: mybatis中的动态代理
mybatis中动态代理存在的意义 图示 图示分析 分层说明:界面层为第一层,业务逻辑层(接口层 + 实现层)为第二层,数据访问层(接口层 + 实现层)为第三层 业务逻辑层和数据访问层:分别分两层来开 ...
- 【Mybatis】MyBatis之动态SQL(六)
MyBatis 的强大特性之一便是它的动态 SQL,本章介绍动态 SQL 查看本章,请先阅读[Mybatis]MyBatis对表执行CRUD操作(三). 本例表结构 CREATE TABLE `emp ...
- 【Mybatis】MyBatis之Sql配置文件的使用(四)
上一章[Mybatis]MyBatis对表执行CRUD操作(三),已经讲了基本操作,本章介绍Sql配置文件中常用功能 1.插入返回主键 2.参数值的获取方式 3.resultMap使用 插入返回主键 ...
随机推荐
- jquery制作弹出层带遮罩效果,点击阴影部分层消失
jquery制作弹出层带遮罩效果,点击阴影部分层消失. 整体还是比较简单的. HTML代码很简单 <a href="#" class="big-link" ...
- which type of VS files should be committed into a version control system
which type of VS files should be committed into a version control system? aps, no: last resource edi ...
- MyBatis-NET
http://www.codeproject.com/Articles/894127/MyBatis-NET https://mybatis.github.io/mybatis-3/
- C# 特殊处理
一.日期格式化处理 private Datetime _datetime;//定义字段 数据值都存在字段里 通过修改字段来修改属性 public string Datetime//定义属性 { get ...
- java 8种基本数据类型的默认值及所占字节数
通过一段代码来测试一下 8种基本数据类型的默认值 package dierge; public class Ceshi { int a; double b; boolean c; char d; fl ...
- wait() notify()搭配synchronize的使用
一直以为自己动多线程,使用过好像就懂了原理一样,其实是按部就班的写自己不知道原理的代码而已. 一些概念: 监视器:将监视器比作一个建筑,建筑里面有个特别的房间,房间中有一些数据,这些数据在同一个时间只 ...
- java swing 去掉按钮文字周围的焦点框
闲来无事,写了个swing界面,运行后看到当点击按钮时,中间文字会出现一个刚好把文字围住的小方框,这是按钮获得焦点的标志,我是觉得一个字:丑!怎么去掉呢?万能的度娘告诉我,设置下button的setF ...
- Mac OS X 访问 Windows 共享文件夹
Mac OS X 访问 Windows 共享文件夹 mac没有网络邻居,但可以使用finder访问局域网中windows共享的文件 1.点击 Finder 前往菜单中的「前往服务器」(或快捷键 com ...
- PHP-仿ecshop生成验证码
<?php /* 生成验证码 */ // 1.创建画布(基于已有图像) $n = mt_rand(1,5); $im = imagecreatefromjpeg('./images/captch ...
- android开源系列之——xUtils 开源库
http://blog.csdn.net/lijunhuayc/article/details/40585607