tkMybatis配置

tkmybatis是基于Mybatis框架开发的一个工具,通过调用它提供的方法实现对单表的数据操作,以免写任何sql语句。

tkMybatis通常与Mybatis以及Mybatis Generator结合使用,实现数据库Model和Mapper的自动化创建的同时方便对单表进行操作。

  • 引入依赖

<dependencies>中引入依赖

            <dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper-spring-boot-starter</artifactId>
<version>2.0.3</version>
</dependency>

<build><plugins>中添加mybatis generator和tkmybatis相关依赖

            <plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.6</version>
<configuration>
<configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml
</configurationFile>
<overwrite>true</overwrite>
<verbose>true</verbose>
</configuration>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.29</version>
</dependency>
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper</artifactId>
<version>4.0.0</version>
</dependency>
</dependencies>
</plugin>
  • 配置Mybatis Generator

    在你的resources文件夹中创建generator文件夹,并创建generatorConfig.xml
<?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> <context id="Mysql" targetRuntime="MyBatis3Simple" defaultModelType="flat">
<property name="javaFileEncoding" value="UTF-8"/>
<property name="beginningDelimiter" value="`"/>
<property name="endingDelimiter" value="`"/> <plugin type="tk.mybatis.mapper.generator.MapperPlugin">
<property name="mappers" value="tk.mybatis.mapper.common.Mapper"/>
</plugin> <!-- 数据源配置 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/table"
userId="root"
password="1234">
</jdbcConnection> <!-- 实体生成路径 -->
<javaModelGenerator targetPackage="com.example.entity" targetProject="src/main/java"/> <!-- xml配置文件生成路径 -->
<sqlMapGenerator targetPackage="mapper.xml" targetProject="src/main/resources"/> <!-- Mapper文件生成位置 -->
<javaClientGenerator targetPackage="com.example.mapper" targetProject="src/main/java"
type="XMLMAPPER"/> <!-- 对要进行自动生成的表进行配置 -->
<table tableName="t_order" domainObjectName="Order">
<generatedKey column="id" sqlStatement="Mysql" identity="true"/>
</table>

注:现在Mysql的的最新数据源驱动为com.mysql.cj.jdbc.Driver,如要使用该驱动,mysql-connector-java的版本请选择8.0以上版本

配置完成后,可以在Maven命令中找到mybatis-generator实现自动生成

  • tkmybatis的使用

    tkmybatis.mapper.common.Mapper提供了单表操作的各种方法,如下所示:
@RegisterMapper
public interface Mapper<T> extends BaseMapper<T>, ExampleMapper<T>, RowBoundsMapper<T>, Marker {
}

则可以直接使用该类,并调用接口方法实现SQL

public abstract class BaseService<T> {

    @Autowired
protected Mapper<T> mapper; //主键查询
public T findOne(Object key) {
return mapper.selectByPrimaryKey(key);
} // 条件查询
public List<T> find(Criteria<T> criteria) {
return mapper.selectByExample(criteria.example());
}
}

同时实现条件查询,可以继承tk.mybatis.mapper.entity.SqlsCriteria和使用Sqls.Criteria来实现

思路就是利用Criteria来构建条件,再转化成Example来实现。

也可以通过Example.createCriteria()来构建Example,不过灵活性稍差

public class Criteria<T> implements tk.mybatis.mapper.entity.SqlsCriteria
{
private Sqls.Criteria criteria; private Class<T> clas; private Criteria(Class<T> clas) {
this.clas = clas;
this.criteria = new Sqls.Criteria();
} public static <T> Criteria<T> getInstance(Class<T> clas) {
return new Criteria<>(clas);
} public Criteria<T> andIsNull(String property) {
this.criteria.getCriterions().add(new Sqls.Criterion(property, "is null", "and"));
return this;
} //通过Lambda表达式获得字段名
public Criteria<T> andIsNull(Fn<T, Object> fn) {
return this.andIsNull(Reflections.fnToFieldName(fn));
} @Override
public Sqls.Criteria getCriteria() {
return criteria;
} //转换成example
public Example example() {
//根据criteria构建Example
Example.Builder where = new Example.Builder(clas).where(this);
return where.build();
}
}

tkMybatis和Mybatis Generator的结合使用的更多相关文章

  1. springboot中通用mapper结合mybatis generator的使用

    通用mapper就是指的是  tk.mybatis  包下的.这个是通用mapper就是说自动生成的dao层需要继承这个框架提供的mapper类.而我们之前用的org.mybatis这个最开始是普通的 ...

  2. mybatis Generator生成代码及使用方式

    本文原创,转载请注明:http://www.cnblogs.com/fengzheng/p/5889312.html 为什么要有mybatis mybatis 是一个 Java 的 ORM 框架,OR ...

  3. 使用MyBatis Generator自动创建代码(dao,mapping,poji)

    连接的数据库为SQL server2008,所以需要的文件为sqljdbc4.jar 使用的lib库有: 在lib库目录下新建一个src文件夹用来存放生成的文件,然后新建generatorConfig ...

  4. mybatis generator 自动生成dao层映射代码

    资源: doc url :http://www.mybatis.org/generator/ download:https://github.com/mybatis/generator/release ...

  5. mybatis generator maven插件自动生成代码

    如果你正为无聊Dao代码的编写感到苦恼,如果你正为怕一个单词拼错导致Dao操作失败而感到苦恼,那么就可以考虑一些Mybatis generator这个差价,它会帮我们自动生成代码,类似于Hiberna ...

  6. mybatis generator.xml 配置 自动生成model,dao,mapping

    generator.xml文件: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE gener ...

  7. Mybatis generator的使用

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration ...

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

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

  9. 记一次 IDEA mybatis.generator 自定义扩展插件

    在使用 idea mybatis.generator 生成的代码,遇到 生成的代码很多重复的地方, 虽然代码是生成的,我们也不应该允许重复的代码出现,因为这些代码后期都要来手动维护. 对于生成时间戳注 ...

随机推荐

  1. JavaScript学习系列博客_27_JavaScript 遍历数组

    遍历数组 - 遍历数组就是将数组中元素都获取到 - 一般情况我们都是使用for循环来遍历数组: - 使用forEach()方法来遍历数组(不兼容IE8) forEach()方法需要一个回调函数(由我们 ...

  2. javaweb中自己遇到的问题

    1.web中的编码问题 1.1服务器接收的数据 post请求,请求会在Servlet中进行解码,所以我们只需要对request设置UTF-8即可. request.setCharacterEncodi ...

  3. MySQL数据和索引占用空间查询

    MySQL数据和索引占用空间查询 查询所有数据库占用磁盘空间大小的SQL语句 SELECT table_schema, -- 数据库名称 concat( TRUNCATE ( sum( data_le ...

  4. android开发之使edittext输入弹出数字软键盘。亲测可用。手机号登陆注册常用。

    <EditText android:id="@+id/edit_digit_input" android:layout_width="wrap_content&qu ...

  5. 深入理解计算机系统 Start && 第一章要点

    对此书已经慕名已久了,抽空看了第1,2,3,5章,其他章节等有空闲继续看吧. 我的许多博客是给自己快速复习使用的,比如此读书后感,你可以根据我下面的建议读完原书几章再回来复习一下(或许那时候就没必要回 ...

  6. 【平台开发】— 8.前端-从[项目管理]来看vue

    现在要来实现[项目管理]这个功能了. 想象一下页面,元素大概就是:列表页.查询框.新增按钮.编辑.mock入口按钮. 那先来实现列表和新建,也顺带着整理一下用到的vue相关指令知识. 一.后端 后端就 ...

  7. Codeforces Round #560 (Div. 3)A-E

    A. Remainder output standard output You are given a huge decimal number consisting of nn digits. It ...

  8. 如何编写一个简单的Linux驱动(一)

    前言 最近在学习Linux驱动,记录下自己学习的历程. 驱动的基本框架 Linux驱动的基本框架包含两部分,“模块入口.出口的注册”和“模块入口.出口函数的实现”,如下方代码. static int ...

  9. vue 多代理

    多代理就要建立多个axios实例对象 vueconfig devServer: { open: true, host: "localhost", // host: "10 ...

  10. FastDFS+nginx整合模块安装

    FastDFS安装 安装gcc编译器 yum -y install gcc automake autoconf libtool make 上传解压两个文件包 libfastcommon是从FastDF ...