mybatis

Mybatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

但mybatis有个比较头疼的一个问题是sql工作量很大,尤其是字段多的时候。虽然说单表的增删改查操作可以通过mybatis generator工具来生成(或者自己写模板工具生成),但项目开发的过程中总免不了要新添加新字段,这些工具就没多大作用,所以要么把新字段写到原来的所有增删改查的sql中,要么删了重新生成。这是个痛苦的过程,特别是当你重复了很多次之后。

mybatis-plus

而mybatis-plus这样一个框架,一种集mybatis与hibernate的优点一起的框架。它提供了hibernate的单表CRUD操作的方便同时,又保留了mybatis的特性。

先来看看官方怎么解释mybatis-plus的:

Mybatis-Plus(简称MP)是一个Mybatis的增强工具,在 Mybatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

快速使用步骤:

1.添加pom文件依赖

org.apache.velocity

velocity

1.7

com.baomidou

mybatis-plus

2.0.1

注意:mybatis-plus会自动维护mybatis以及mybatis-spring的依赖,所以不需要引入后两者,避免发生版本冲突.

2.修改配置文件

将mybatis的sqlSessionFactory替换成mybatis-plus的即可,mybatis-plus只做了一些功能的扩展:

<bean id="sqlSessionFactory" class="com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean"><property name="dataSource" ref="dataSource"/>

<property name="mapperLocations" value="classpath:mybatis/*/*.xml"/><property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/><property name="typeAliasesPackage" value="com.baomidou.springmvc.model.*"/><property name="plugins"><array>

<bean id="paginationInterceptor" class="com.baomidou.mybatisplus.plugins.PaginationInterceptor"><property name="dialectType" value="mysql"/>bean>array>property>

<property name="globalConfig" ref="globalConfig" /> bean>

在上面的配置中,除了mybatis的常规配置,多了一个分页插件的配置和全局配置,mybatis-plus提供了很方便的使用分页的插件,还有一个全局配置如下:

<bean id="globalConfig" class="com.baomidou.mybatisplus.entity.GlobalConfiguration">

<property name="idType" value="2" />

<property name="dbColumnUnderline" value="true" />bean>

至此,配置工作就算大功告成了,接下来通过一个简单的例子来感受一下它的使用.

1.新建一个User表:

@TableName("user")public class User implements Serializable {/** 用户ID */ private Long id;/** 用户名 */ private String name;/** 用户年龄 */ private Integer age;@TableField(exist = false) private String state;}

这里有两个注解需要注意,第一是@tableName("user"),它是指定与数据库表的关联,这里的注解意味着你的数据库里应该有一个名为user的表与之对应,并且数据表的列名应该就是User类的属性,对于User类中有而user表中没有的属性需要加第二个注解@TableField(exist = false),表示排除User类中的属性.

2.新建Dao层接口UserMapper:

/** * User 表数据库控制层接口 */public interface UserMapper extends BaseMapper<User> {@Select("selectUserList")List selectUserList(Pagination page,String state);}

dao接口需要实现Basemapper,这样就能够使用封装好的很多通用方法,另外也可以自己编写方法,@select注解引用自第三步的UserMapper文件

3.新建UserMapper配置文件:

xml version="1.0" encoding="UTF-8"?><mapper namespace="com.baomidou.springmvc.mapper.system.UserMapper"><sql id="Base_Column_List"> id, name, agesql><select id="selectUserList" resultType="User"> SELECT * FROM sys_user WHERE state=#{state}select>mapper>

4.新建service层类UserService:

/** * * User 表数据服务层接口实现类 * */@Servicepublic class UserService extends ServiceImpl, User>{ public Page<User> selectUserPage(Page<User> page, String state) { page.setRecords(baseMapper.selectUserList(page,state));return page; }}

UserService继承了ServiceImpl类,mybatis-plus通过这种方式为我们注入了UserMapper,这样可以使用service层默认为我们提供的很多方法,也可以调用我们自己在dao层编写的操作数据库的方法.Page类是mybatis-plus提供分页功能的一个model,继承了Pagination,这样我们也不需要自己再编写一个Page类,直接使用即可.

5,新建controller层UserController

@Controllerpublic class UserController extends BaseController {@Autowiredprivate IUserService userService;@ResponseBody@RequestMapping("/page") public Object selectPage(Model model){Page page=new Page(1,10); page = userService.selectUserPage(page, "NORMAL");return page; }

以上就完成了一个基本的功能,下面来看一下它的条件构建器.

mybatis-plus的条件构建器

首先看一个条件构建器实例的简单实用.

public void test(){ EntityWrapper ew=new EntityWrapper(); ew.setEntity(new User()); String name="wang"; Integer age=16; ew.where("name = {0}",name).andNew("age > {0}",age).orderBy("age"); List list = userService.selectList(ew); Page page2 = userService.selectPage(page, ew); }

mybatisgenerator使用_如何优雅地使用MyBatisplus相关推荐

  1. git bash命令_更优雅地使用命令行

    工欲善其事,必先利其器,通过武装自己的命令行工具,从而更优雅地使用命令行,可以使工作更加高效并且有趣.本文将以下几个方面来介绍命令行的使用技巧和提效工具 CLI 一键呼入呼出 iterm2 是一款完全 ...

  2. python如何删除对象属性_如何优雅的删除对象中的指定属性?

    要优雅的话,使用 Lodash 的 omit 方法移除不要的属性: const object = { 'a': 1, 'b': '2', 'c': 3 }; const result = _.omit ...

  3. c++如何把字符串转为变量名_如何优雅地计算多变量

    作者:包寒吴霜 中科院心理所硕士在读(名字/人格/社会/文化心理学) 知乎:https://www.zhihu.com/people/psychbruce 社会科学研究经常会遇到"超多变量& ...

  4. antd select 下拉菜单的 style 属性_如何优雅地彻底解决 antd 全局样式问题

    背景 由于某些原因,我们团队负责在 GitLab 上做二次开发,简单理解就是在 GitLab 上挂个 DOM 渲染用 React 写的一些组件,组件库选择了 antd,尴尬的是引入之后发现,GitLa ...

  5. python怎么打开ipynb文件_如何优雅的打开.ipynb文件

    目前在windows打开.ipynb的文件的方法,网上几乎就只有一种,在cmd下 > jupyter notebook 这个方法只是方便你新建notebook的时候.如果你想再打开它,当你优雅的 ...

  6. 对文本根据特殊字符进行分段代码_如何优雅地配置快应用的代码片段

    本文使用 Zhihu On VSCode 创作并发布 作为一名程序员,在编码的过程中,难免会遇到要写些重复性的代码:假如每次都重新码一遍,既浪费了时间,也有伤身体.倘若可以配置一个像快捷键一样,输入简 ...

  7. mysql怎么备份和恢复_如何优雅的备份和恢复Mysql数据库?

    谢邀,个人认为从标题看,是个比较大而且值得数据库从业者思考的问题:从问题描述看,又是一个比较浅显的问题. 先从问题描述看,mysqldump 备份和恢复时往往会有各种错误,如何避免?mysqldump ...

  8. nginx没有worker进程_如何优雅地关闭worker进程?

    点击上方"武培轩",选择"设为星标" 技术文章第一时间送达! 之前我们讲解 Nginx 命令行的时候,可以看到 Nginx 停止有两种方式,分别是 nginx ...

  9. react生命周期函数_如何优雅的消灭掉react生命周期函数

    开源不易,感谢你的支持,❤ star concent^_^ 序言 在react应用里,存在一个顶层组件,该组件的生命周期很长,除了人为的调用unmountComponentAtNode接口来卸载掉它和 ...

最新文章

  1. 这家公司不要求996,但照样市值万亿!
  2. 开源大数据查询分析引擎
  3. clion 快捷键_Ctrl+Shift系列快捷键的16个应用技巧都不掌握,那就真的Out了
  4. c#quartz触发_SpringBoot集成Quartz实现定时任务
  5. 博士出身好科研产出高,学术谱系真的可以决定一切吗?
  6. 将Myeclipse非maven项目,导入到IDEA
  7. 设置Qt直接运行路径
  8. java 阻塞队列 BQ_阻塞队列 BlockingQueue的使用(二)
  9. M1升级MacOS Monterey后,如何使用空间音频?
  10. Oracle 触发器 判断
  11. java roll_java.util.Calendar roll()方法
  12. 关于游戏乐趣的几点思考
  13. 产品思维30讲(梁宁)-- 整体
  14. Java反射基础指南
  15. 20120821-GetDC
  16. 技术之路也要懂得理财-------林左鸣:建设军工强国的5条锦囊妙计
  17. 事关健康、教育和工资 | 1月起,这些事有变化 |
  18. python中aorb是什么意思_Python--AB测试应用分析
  19. Wannafly挑战赛20-染色
  20. 行之有效:第一章观后有感

热门文章

  1. 与小熊、新宝不同的北鼎,仍不是小家电的出路
  2. python练习集100题_8道关于python的练习题
  3. python语法总结下载_python语法总结1
  4. SQL 登录注入脚本_常见web安全问题,SQL注入、XSS、CSRF,基本原理以及如何防御...
  5. php ajax邮箱,PHP+Ajax异步通讯实现用户名邮箱验证是否已注册( 2种方法实现)
  6. 全面讲解Python列表数组(三)列表数组类型的内置函数方法
  7. 零基础学Python:自定义序列类的详细教程
  8. python下timer定时器常用的两种实现方法
  9. Python教程:hashlib加密
  10. Python 中文分词(结巴分词)