springboot整合tkmybatis以及使用

springboot整合tkmybatis以及使用经常用 mybatis 的的都知道 使用 mybatisorm 框架存在一个非常不友善的问题就是 就是每操作一个单表就需要自己手写一个 xml 文件 虽然说可以用工具生成 xml 和实体类可以解决这个问题 但是二次开发的时候对某个表字段进行修改的时候 生成 xml 文件就不现实啦 最近发现 tkmybatis 就非常好的解决了这个问题 在这里和大家分享一下 框架配置这里需要引用到的包 mybat

经常用mybatis的的都知道,使用mybatis orm框架存在一个非常不友善的问题就是,就是每操作一个单表就需要自己手写一个xml文件,虽然说可以用工具生成xml和实体类可以解决这个问题,但是二次开发的时候对某个表字段进行修改的时候,生成xml文件就不现实啦。最近发现tkmybatis就非常好的解决了这个问题。在这里和大家分享一下。

  • 框架配置

这里需要引用到的包

 <!--mybatis操作数据库有关--> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.2</version> </dependency> <!--连接mysql--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency> <!--使用阿里巴巴的druid数据源,有利于监控sql的执行情况--> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.1.10</version> </dependency> <!--通用mapper--> <dependency> <groupId>tk.mybatis</groupId> <artifactId>mapper-spring-boot-starter</artifactId> <version>2.1.2</version> </dependency> <!--添加lombok支持,可以省掉写get和set方法--> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.16.10</version> <optional>true</optional> </dependency> <!--使用fastjson来操作json数据--> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.31</version> </dependency> <!--spring boot web方面的支持--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.1.4.RELEASE</version> </dependency> 

数据源配置

spring: datasource: url: jdbc:mysql://localhost:3306/test username: root password: root driver-class-name: com.mysql.cj.jdbc.Driver 

表结构语句

DROP TABLE IF EXISTS `user`; CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `user_name` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `user_phone` varchar(11) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, PRIMARY KEY (`id`) USING BTREE, INDEX `user_name_index`(`user_name`) USING BTREE ) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact; -- ---------------------------- -- Records of user -- ---------------------------- INSERT INTO `user` VALUES (1, 'evan', '26'); INSERT INTO `user` VALUES (2, 'evan11', '26'); 
  • 类配置方法
    实体类方法
    注意这里是引用了lombok框架,可以省略写get,set之类的方法,这里需要idea里面添加lombok插件,如果有报错的话。(如果有强迫症的话)其实还是代码还是可以跑起来的。

@Data @Table(name="user") public class UserModel { @Id @GeneratedValue(strategy = GenerationType.IDENTITY,generator = "JDBC") private Integer id; @Column private String userName; @Column private String userPhone; } 

在这里插入图片描述

  • Service类
    这里主要是实现了上边BaseMapper中继承的5个Mapper的方法。
    tk.mybatis.mapper.common.BaseMapper中有较多方法,均需要继承实现:

 / * 保存一个实体,null属性也会保存 * * @param record * @return */ int insert(T record); / * 保存一个实体,null属性不会保存 * * @param record * @return */ int insertSelective(T record); / * 根据实体属性作为条件进行删除,查询条件使用等号 */ int delete(T record); / * 根据主键更新属性不为null的值 */ int updateByPrimaryKeySelective(T record); / * 根据实体中的属性值进行查询,查询条件使用等号 */ List<T> select(T record); / * 查询全部结果,select(null)方法能达到同样的效果 */ List<T> selectAll(); / * 根据实体中的属性进行查询,只能有一个返回值,有多个结果是抛出异常,查询条件使用等号 */ T selectOne(T record); / * 根据实体中的属性查询总数,查询条件使用等号 */ int selectCount(T record); 

MySqlMapper中的方法如下:

/ * 批量插入,支持批量插入的数据库可以使用,例如MySQL,H2等,另外该接口限制实体包含`id`属性并且必须为自增列 */ public int insertList(List<T> recordList); / * 插入数据,限制为实体包含`id`属性并且必须为自增列,实体配置的主键策略无效 */ public int insertUseGeneratedKeys(T record); 

IdsMapper中的方法如下:

 / * 根据主键@Id进行查询,多个Id以逗号,分割 * @param id * @return */ List<T> selectByIds(String ids); / * 根据主键@Id进行删除,多个Id以逗号,分割 * @param id * @return */ int deleteByIds(String ids); 

ConditionMapper中的方法如下:

/ * 根据Condition条件进行查询 */ public List<T> selectByCondition(Object condition); / * 根据Condition条件进行查询 */ public int selectCountByCondition(Object condition); / * 根据Condition条件删除数据,返回删除的条数 */ public int deleteByCondition(Object condition); / * 根据Condition条件更新实体`record`包含的全部属性,null值会被更新,返回更新的条数 */ public int updateByCondition(T record, Object condition); / * 根据Condition条件更新实体`record`包含的全部属性,null值会被更新,返回更新的条数 */ public int updateByConditionSelective(T record, Object condition); 

ExampleMapper中的方法如下:

/ * 根据Example条件进行查询 */ public List<T> selectByExample(Object example); / * 根据Example条件进行查询,若有多条数据则抛出异常 */ public T selectOneByExample(Object example); / * 根据Example条件进行查询总数 */ public int selectCountByExample(Object example); / * 根据Example条件删除数据,返回删除的条数 */ public int deleteByExample(Object example); / * 根据Example条件更新实体`record`包含的全部属性,null值会被更新,返回更新的条数 */ public int updateByExample(T record, Object example); / * 根据Example条件更新实体`record`包含的不是null的属性值,返回更新的条数 */ public int updateByExampleSelective(T record, Object example); 

使用方法

ExampleMapper内方法使用说明:

 Example example = new Example(UserModel.class); Example.Criteria criteria = example.createCriteria(); criteria.andEqualTo("id","1"); criteria.orEqualTo("userName","evan11"); 
Example example = new Example(UserRole.class);//实例化 Example.Criteria criteria = example.createCriteria(); 
 Example example = new Example(UserModel.class); Example.Criteria criteria = example.createCriteria(); criteria.andEqualTo("id","1"); criteria.orEqualTo("userName","evan11"); List<UserModel> userModels = userDao.selectByExample(example); 

最总输出的sql语句是

Preparing: SELECT id,user_name,user_phone FROM user WHERE ( ( id = ? and user_name = ? ) ) Parameters: 1(String), evan11(String) 

其中andCondition(String condition)方法支持手写条件,传入的字符串为最终的查询条件,如:length(f_user_id)<5

以及likeTo()的方法是不带百分号%的,需要自己对传入参数进行构建(加左like或者右like等)。

其余方法自行见源码,不再赘述。

ConditionMapper内方法使用说明:
所有方法均需要传入tk.mybatis.mapper.entity.Condition,Condition实际上继承自tk.mybatis.mapper.entity.Example,
源码中有三个方法:

 public Condition(Class<?> entityClass) { super(entityClass); } public Condition(Class<?> entityClass, boolean exists) { super(entityClass, exists); } public Condition(Class<?> entityClass, boolean exists, boolean notNull) { super(entityClass, exists, notNull); } 

其使用方法与Example类似

 Condition condition = new Condition(UserRole.class); Criteria criteria = condition.createCriteria(); criteria.andEqualTo("id","1"); criteria.orEqualTo("userName","evan11"); List<UserModel> userModels = userDao.selectByExample(example); 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233863.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c语言飞机订票系统设计,飞机订票系统设计「建议收藏」

    c语言飞机订票系统设计,飞机订票系统设计「建议收藏」该楼层疑似违规已被系统折叠隐藏此楼查看此楼u=find_num_hlink_list(save,book_flight_num);strcpy(ticket_x1.flight_num,u->info.flight_num);strcpy(ticket_x1.start_add,u->info.start_add);strcpy(ticket_x1.end_add,u->inf…

    2022年6月16日
    27
  • BS架构与CS架构的区别(最详细)「建议收藏」

    BS架构与CS架构的区别(最详细)「建议收藏」BS架构与CS架构的区别引言特点C/S系统结构B/S系统结构CS与BS的比较C/S与B/S区别:现状与趋势(转自知乎)引言C/S结构,即Client/Server(客户机/服务器)结构,是大家熟知的软件系统体系结构,通过将任务合理分配到Client端和Server端,降低了系统的通讯开销,可以充分利用两端硬件环境的优势。早期的软件系统多以此作为首选设计标准。B/S结构,即Browse…

    2022年10月17日
    2
  • qmap的书写格式linux,QMap 键值存储「建议收藏」

    qmap的书写格式linux,QMap 键值存储「建议收藏」Qt中的QMap介绍与使用,在坛子里逛了一圈,发现在使用QMap中,出现过很多的问题,Map是一个很有用的数据结构。它以“键-值”的形式保存数据。在使用的时候,通过提供字符标示(键)即可得到想要的数据。这个“数据”即可以是一个字符串,也可以是任意对象,当然也包括自己定义的类对象。说明:map是以值传递的形式保存数据的。1.基本应用下面以“键-值”都是QString的例子说明QMap的基本使用方法…

    2022年5月7日
    77
  • 2021idea激活码【2021免费激活】

    (2021idea激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月26日
    109
  • 如何将excel表格导入mysql数据库_MySQL数据库

    如何将excel表格导入mysql数据库_MySQL数据库怎么把excel里的数据导入数据库中的表中打开企业管理器开要导入数数据库,在表上按右键,所务–>导入数据,弹出DTS导入/导出向导,按下一步,2、选择数据源MicrosoftExcel97-2000,文件名选择要导入的xls文件,按下一步,3、选择目的用于SQLServer的MicrosoftOLEDB提供程序,服务器选择本地(如果是本地数据库的话,如VVV…

    2022年9月21日
    4
  • vim配置vimrc详解

    vim配置vimrc详解vimrc的存放位置:#系统vimrc文件:”$VIM/vimrc”用户vimrc文件:”$HOME/.vimrc”用户exrc文件:”$HOME/.exrc”系统gvimrc文件:”$VIM/gvimrc”用户gvimrc文件:”$HOME/.gvimrc”系统菜单文件:”$VIMRUNTIME/menu.vim”$VIM预设值:”/usr/share/vim”vimrc文件内容:syntaxon”自动语法高亮”…

    2022年5月30日
    45

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号