范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

最快MyBatisPlus入门使用

  笔者于2016年入Java,先后从事开发和教育行业,现就职于某供应链公司担任后端开发工程师。整理分享开发必备技术文档。
  收藏等于学会,赶紧三连吧,如有问题请评论区留言或者私信哦!一、MyBatis-Plus介绍
  1.1、概述
  这个技术官网介绍已经非常详细MyBatis-Plus,MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。愿景是成为 MyBatis 最好的搭档,就像 魂斗罗 中的 1P、2P,基友搭配,效率翻倍。
  1.2、特征
  无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑损耗小:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作强大的 CRUD 操作:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求支持 Lambda 形式调用:通过 Lambda 表达式,方便的编写各类查询条件,无需再担心字段写错支持多种数据库:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer2005、SQLServer 等多种数据库支持主键自动生成:支持多达 4 种主键策略(内含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解决主键问题支持 XML 热加载:Mapper 对应的 XML 支持热加载,对于简单的 CRUD 操作,甚至可以无 XML 启动支持 ActiveRecord 模式:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD 操作支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere )支持关键词自动转义:支持数据库关键词(order、key......)自动转义,还可自定义关键词内置代码生成器:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码,支持模板引擎,更有超多自定义配置等您来使用内置分页插件:基于 MyBatis 物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通 List 查询内置性能分析插件:可输出 Sql 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询内置全局拦截插件:提供全表 delete 、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作内置 Sql 注入剥离器:支持 Sql 注入剥离,有效预防 Sql 注入攻击
  1.3、框架结构
  二、快速开始
  2.1、技术背景
  我在该案例中使用的是IDEA开发工具,使用的是ssm框架大家也可以使用springboot,数据库使用的是mysql,框架的搭建整合就不做演示了,不会的可以参考我之前的博客。
  2.2、开搞
  2.2.1、创建数据库
  我们使用mybatis无疑是操作数据库,所以我们首先需要创建一个数据库和数据表,如下
  CREATE TABLE `user` (   `id` int(11) NOT NULL AUTO_INCREMENT,   `name` varchar(255) DEFAULT NULL,   `pass` varchar(255) DEFAULT NULL,   PRIMARY KEY (`id`) USING BTREE ) ENGINE=InnoDB AUTO_INCREMENT=14 DEFAULT CHARSET=utf8;
  对应的插入语句
  INSERT INTO user (id, name, pass) VALUES (1, "aa", "sss"); INSERT INTO user (id, name, pass) VALUES (2, "dd", "dd"); INSERT INTO user (id, name, pass) VALUES (3, "朱重八", "123"); INSERT INTO user (id, name, pass) VALUES (4, "朱五四", "123"); INSERT INTO user (id, name, pass) VALUES (5, "朱元璋", "123"); INSERT INTO user (id, name, pass) VALUES (6, "朱由检", "123");
  2.2.2、创建工程
  这里提供SpringMVC和SpringBpoot两种方式,我们使用IDEA创建一个Maven工程,主要修改pom.xml文件,spring与mybatis的整合文件
  SpringMVC
  1)pom.xml文件,引入mybatis-plus的依赖
              com.baomidou       mybatis-plus       3.1.1     
  注意:引入 MyBatis-Plus 之后请不要再次引入 MyBatis 以及 MyBatis-Spring,以避免因版本差异导致的问题
  如果你是用的是springboot项目则添加以下启动器
       com.baomidou     mybatis-plus-boot-starter     3.1.1 
  2)整合文件
  SpringMVC
  配置 MapperScan
   		 	
  调整 SqlSessionFactory 为 MyBatis-Plus 的 SqlSessionFactory
           	         	         	     		         
  SpringBoot配置
  @SpringBootApplication @MapperScan("com.zhiyou100.mapper") public class Application {      public static void main(String[] args) {         SpringApplication.run(QuickStartApplication.class, args);     }  }
  以上就是使用mybatis-plus的配置文件的配置,接下来我们看看在代码中如何实现CRUD操作。
  2.2.3、编码
  1)实体类
  package com.zhiyou100.pojo;  import lombok.Data; import lombok.ToString;  @Data @ToString public class User {     private Integer id;     private String name;     private String pass;  }
  小结:这里实体类使用的是lombok插件,可以不用写getter,setter等方法
  2)mapper类
  package com.zhiyou100.mapper;  import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.zhiyou100.pojo.User;  public interface User2Mapper extends BaseMapper {  }
  小结:我们创建Mapper类,继承BaseMapper,BaseMapper中定义了一些通用的CRUD方法,我们甚至可以不用写实体类的映射文件就可以完成一些简单的CRUD操作
  BaseMapper源码如下,不难应该都能看懂,但是需要注意的是你的数据库的表名和字段名必须和实体类名和属性名一致 。
  public interface BaseMapper extends Mapper {     int insert(T entity);      int deleteById(Serializable id);      int deleteByMap(@Param("cm") Map columnMap);      int delete(@Param("ew") Wrapper wrapper);      int deleteBatchIds(@Param("coll") Collection<? extends Serializable> idList);      int updateById(@Param("et") T entity);      int update(@Param("et") T entity, @Param("ew") Wrapper updateWrapper);      T selectById(Serializable id);      List selectBatchIds(@Param("coll") Collection<? extends Serializable> idList);      List selectByMap(@Param("cm") Map columnMap);      T selectOne(@Param("ew") Wrapper queryWrapper);      Integer selectCount(@Param("ew") Wrapper queryWrapper);      List selectList(@Param("ew") Wrapper queryWrapper);      List> selectMaps(@Param("ew") Wrapper queryWrapper);      List selectObjs(@Param("ew") Wrapper queryWrapper);      IPage selectPage(IPage page, @Param("ew") Wrapper queryWrapper);      IPage> selectMapsPage(IPage page, @Param("ew") Wrapper queryWrapper); }
  3)测试
  @RequestMapping("queryall.do")     @ResponseBody     public List queryall(){         List users = user2Mapper.selectList(null);         for (User user : users) {             System.out.println(user);         }         return users;     }
  小结:到此使用mybatis-plus完成了一个简单的单表查询,其余的添加,修改,删除,只需要调用对应的方法即可。
  三、代码生成器
  AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码,极大的提升了开发效率。
  3.1、配置
  添加新的依赖,官网上说MyBatis-Plus 从 3.0.3 之后移除了代码生成器与模板引擎的默认依赖,需要手动添加相关依赖:
       com.baomidou     mybatis-plus-generator     3.1.1 
  引入freemarker依赖:
       org.freemarker     freemarker     2.3.28 
  3.2、工具类
  import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException; import com.baomidou.mybatisplus.core.toolkit.StringPool; import com.baomidou.mybatisplus.core.toolkit.StringUtils; import com.baomidou.mybatisplus.generator.AutoGenerator; import com.baomidou.mybatisplus.generator.InjectionConfig; import com.baomidou.mybatisplus.generator.config.*; import com.baomidou.mybatisplus.generator.config.po.TableInfo; import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy; import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;  import java.util.ArrayList; import java.util.List; import java.util.Scanner;  public class CodeGenerator {     /**      * 

* 读取控制台内容 * */ public static String scanner(String tip) { Scanner scanner = new Scanner(System.in); StringBuilder help = new StringBuilder(); help.append("请输入" + tip + ":"); System.out.println(help.toString()); if (scanner.hasNext()) { String ipt = scanner.next(); if (StringUtils.isNotEmpty(ipt)) { return ipt; } } throw new MybatisPlusException("请输入正确的" + tip + "!"); } public static void main(String[] args) { // 代码生成器 AutoGenerator mpg = new AutoGenerator(); // 全局配置 GlobalConfig gc = new GlobalConfig(); //获取项目的地址 final String projectPath = System.getProperty("user.dir"); System.out.println("projectPath===>"+projectPath); gc.setOutputDir(projectPath + "/src/main/java"); gc.setAuthor("jobob"); gc.setOpen(false); // gc.setSwagger2(true); 实体属性 Swagger2 注解 mpg.setGlobalConfig(gc); // 数据源配置 DataSourceConfig dsc = new DataSourceConfig(); dsc.setUrl("jdbc:mysql://localhost:3306/test?useUnicode=true&useSSL=false&characterEncoding=utf8"); // dsc.setSchemaName("public"); dsc.setDriverName("com.mysql.jdbc.Driver"); dsc.setUsername("root"); dsc.setPassword("123456"); mpg.setDataSource(dsc); // 包配置 final PackageConfig pc = new PackageConfig(); pc.setModuleName(scanner("模块名")); pc.setParent("com.baomidou.ant"); mpg.setPackageInfo(pc); // 自定义配置 InjectionConfig cfg = new InjectionConfig() { @Override public void initMap() { // to do nothing } }; // 如果模板引擎是 freemarker String templatePath = "/templates/mapper.xml.ftl"; // 如果模板引擎是 velocity // String templatePath = "/templates/mapper.xml.vm"; // 自定义输出配置 List focList = new ArrayList(); // 自定义配置会被优先输出 focList.add(new FileOutConfig(templatePath) { @Override public String outputFile(TableInfo tableInfo) { // 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!! return projectPath + "/src/main/resources/mapper/" + pc.getModuleName() + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML; } }); /* cfg.setFileCreate(new IFileCreate() { @Override public boolean isCreate(ConfigBuilder configBuilder, FileType fileType, String filePath) { // 判断自定义文件夹是否需要创建 checkDir("调用默认方法创建的目录"); return false; } }); */ cfg.setFileOutConfigList(focList); mpg.setCfg(cfg); // 配置模板 TemplateConfig templateConfig = new TemplateConfig(); // 配置自定义输出模板 //指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别 // templateConfig.setEntity("templates/entity2.java"); // templateConfig.setService(); // templateConfig.setController(); templateConfig.setXml(null); mpg.setTemplate(templateConfig); // 策略配置 StrategyConfig strategy = new StrategyConfig(); strategy.setNaming(NamingStrategy.underline_to_camel); strategy.setColumnNaming(NamingStrategy.underline_to_camel); strategy.setEntityLombokModel(true); strategy.setRestControllerStyle(true); strategy.setInclude(scanner("表名,多个英文逗号分割").split(",")); strategy.setTablePrefix(pc.getModuleName() + "_"); mpg.setStrategy(strategy); mpg.setTemplateEngine(new FreemarkerTemplateEngine()); mpg.execute(); } }   运行main方法,输入模块名和数据表名就会在对应的目录下生成对应的文件,将他们拷贝到项目中即可。   四、条件构造器   4.1、概述   我们在做对数据的操作时,尤其是查询会有很多的条件,我们使用mybatis-plus如何实现条件查询?给我们提供了条件构造器,是由AbstractWrapper和他的两个子类QueryWrapper(LambdaQueryWrapper) UpdateWrapper(LambdaUpdateWrapper) 实现,用于生成 sql 的 where 条件。一下是AbstractWrapper类的部分方法截图,大家通过这写方法名就恍然大悟。   4.2、实战   我们通过一个案例来掩饰怎么使用,其他的参考官网条件构造器 | MyBatis-Plus照葫芦画瓢即可,这里介绍一个alleq方法,顾名思义,就是所有的条件都要满足即sql语句中的and,好了其他的去官网看吧。   public List query(){ //设置条件,key是数据库中的字段名,value是值 HashMap map = new HashMap(); map.put("name","张三"); map.put("pass","123"); List users = user2Mapper.selectList(new QueryWrapper().allEq(map)); for (User user : users) { System.out.println(user); } return users; }   五、分页插件   我们在项目中做查询必然会用到分页这个功能,我们来看看mybatis-plus中是如何实现的吧!   5.1、配置   我们不需要在pom.xml文件中引入新的依赖。   1)springmvc配置,在mybatis的核心配置文件中即SqlMapConfig.xml文件      2)springboot配置   //Spring boot方式 @EnableTransactionManagement @Configuration @MapperScan("com.zhiyou100.service.*.mapper*") public class MybatisPlusConfig { /** * 分页插件 */ @Bean public PaginationInterceptor paginationInterceptor() { return new PaginationInterceptor(); } }   5.2、编码   1)我们在实体类映射文件中写一个sql      2)mapper类,要分页的话传入的参数需要是Page,返回值是IPage。可以继承BaseMapper也可以不继承自己思考下为什么   public interface User2Mapper extends BaseMapper { IPage selectPage(Page page); }   3)controller类   private List queryAll() { //参数1:当前页,参数2:每页数据量 Page page = new Page(2,5); //也可使用set方法设置 //page.setCurrent(2); //page.setSize(5); IPage userIPage = user2Mapper.selectPage(page); //获取数据List集合。 List records = userIPage.getRecords(); return records; }   致于前端页面上一页下一页就不写了,无非+1-1之类的操作。mybatis-plus还有很多腻害的插件,可以到官网继续学习。


狄龙你们应去采访格林,让他继续讲我,你知道的他很可爱虎扑03月10日讯灰熊以131110击败勇士。赛后,灰熊球员狄龙布鲁克斯接受媒体采访,谈到了勇士球员德雷蒙德格林。你们应该把麦克风递给格林,你们应该去采访他,这样他就能继续谈论我了10万以内都能拿下!三款纯电小车,哪个会是你的小可爱对于很多家用消费群体来说,小型电动车有着很大的吸引力。它们售价便宜停车便捷用车成本极低短途代步轻松优势十分明显。虽说五菱宏光MINIEV比亚迪海豚的出现,直接捧火了该领域,然而在1章子怡破尺度出演,为上映狂删49分钟!连载够吹一辈子的国产片文接上期阅读此文之前,麻烦您点击下关注,方便与您讨论分享,也能及时观看下一篇精彩文章。非常感谢您的关注!上期说琴琴和得意,决定不顾所有人鄙夷的眼光,在生命的最后一刻,毅然决然住在一新版的hicar使用体验抖音微信手机版的百度地图都可以投屏了,B站下载的离线视频也可以直接在车机上看,不错不错。目前比较不满意的地方只有下面3个了1音质,hicar链接之后听歌选歌方面,比直接在车机上链接有了绿联100W智充魔盒Pro,已经不想和桌面凌乱的人说话了随着大家手里的数码设备越来越多,各种插线板充电头数据线堆在一起导致桌面凌乱不堪,让强迫症的自己看着可太难受了,现在我找到一个桌面电源管理神器,在它的帮助下桌面立即恢复整洁,下面就来长文STM32嵌入式面试知识点总结头条创作挑战赛一STM32F1和F4的区别?解答参看STM32开发STM32初识内核不同F1是CortexM3内核,F4是CortexM4内核主频不同F1主频72MHz,F4主频1两会期间,男宝宝取名,取一个从政当官的好名字现在正值两会期间,家中添个男宝宝,父母也会希望孩子走仕途,将来能有理想抱负,为国效力。一个有助于仕途的名字能够为孩子带来好运。既可以体现男孩远大的理想,又融入了吉利的寓意。下面分享创造性的工作才是未来!让AI为你打造更好的未来!它的用户数量在短短一周内就突破了一百万,两个月后用户就已经过亿了。这个数字真的让人难以想象。之前用户增长最快的是一个社交娱乐平台,名为抖音,它用了九个月才突破了一亿的用户。而现在,依旧选择特斯拉,Model3车主换ModelY,行驶4万公里驾驶感受原来开的20款特斯拉Model3的长续航,21年中旬,换了特斯拉ModelY的74度三元锂电池长续航版本,家里也有油车,感觉开完之后对比如下1能耗方面。平常基本上都是在北京市区上下共享单车超区停放,扣调度费合理吗?共享单车是移动互联网和租赁自行车融合而成的新型服务模式,是分享经济的典型业态。在更好地满足公众出行需求有效解决城市交通出行最后一公里的同时,伴随其发展而来的乱停乱放问题,日益成为城美联储褐皮书预计美国未来几个月经济状况不会有太大改善当地时间3月8日,美联储发布经济状况褐皮书。褐皮书显示,美国整体的经济活动在2023年初略有增加,劳动力市场状况依然稳健,通货膨胀压力仍然普遍存在。总体而言,供应链紧张的状况继续缓
行走在日本的民宿人静舍日本草津町民宿的路那是我去年9月愚笨的我本想去轻井泽却订了一间温泉之乡草津町的民宿,或许也是我与民宿结缘初始之地!我一路从东京奔波错过新干线,直到中午坐上了从上野出发的电车,花大汉奸李士群被日本人毒杀,妻子不服,日本人你和丈夫手下通奸1943年9月9日,臭名昭著的大汉奸李士群毒发身亡。李士群临死前大泻不止痛苦万分,他用尽最后一丝力气感叹干了一生特务,不料自己还是被日本人算计了!李士群死后,当地老百姓纷纷敲锣打鼓小米将有王炸新机?双11换机建议再等,推迟一个月或更便宜小米将有王炸新机?双11换机建议再等,推迟一个月或更便宜按照以往惯例,双11以及618是每年购买手机最便宜的时间节点。但今年可能有些例外,原因之一就是在11月中旬大批的骁龙8GenFindX系列历代屏幕回顾节节攀升的跃进,更加期盼下一代这段时间,有关于OPPO新机的影像配置曝光数量,可谓是相当多了。结合绿哥的汇总信息来看,目前有关于OPPO的折叠屏新机,以及明年的OPPOFindX6系列机型的影像配置参数,基本上自定义模式暗含成人内容,守望先锋2遭玩家控诉而外服的青少年玩家能够轻而易举地接触到它。在2019年,守望先锋开放了地图工坊,允许玩家使用既有的游戏模型制作自定义游戏内容和规则。这一功能在守望先锋2中得到继承,像是跑酷大乱斗贪华为轮值董事长胡厚崑5G正从规模商用期跃升到高速发展期10月25日,以5GLeadstheStride为主题的2022全球移动宽带论坛在曼谷举行。华为轮值董事长胡厚崑以5G引领飞跃为主题作了发言,表示5G正在从规模商用期跃升到高速发展科技头条真实体验男人玩具,魅族PANDAER白金独角兽赛博音箱虽然魅族PANDAER这款音箱已经出蛮久了虽然已经看过不少美图评测,但拿到实物仍然是让人爱不释手。金属铆钉机体,阻尼感不错的机械按键与旋钮,细节满满的RGB灯效,别说我这种直男了,江湖晚报2022年10月24日每日精选科技资讯20点发布欢迎订阅江湖晚报每晚20003分钟了解当天科技资讯2022年10月24日星期一别忘了关注订阅1。根据消息,苹果正在研发其第一款高端Mac桌面电脑,其芯片配置至少是M2Max的两到四倍,被称10英寸8K屏光源黑科技!ELEGOO双11新品SATURN2钜惠来袭近年来,3D打印机在普通消费者群体中得到快速普及。消费者对家用3D打印机的性能体验也提出更高的要求。眼看双十一马上就到了,相信3D打印爱好者们都渴望选购到一款能让自己满意的高性价比芝柏推出Laureato桂冠系列38毫米Copper腕表芝柏表(GirardPerregaux)隆重推出Laureato桂冠系列38毫米Copper腕表,突破性别界限,绽放迷人魅力。全新表款承袭了1975年问世的Laureato桂冠系列荣耀折叠屏曝光!大电池高性能处理器,或将11月发布荣耀自从与华为分离之后,就不断更改自己的新机发布策略,数字系列从一年一更转化成了一年两更,而在最近也发布了最新的荣耀X系列机型荣耀X40,这款手机以圆环摄像头设计以及曲面屏的设计获