mybatis-plus入门使用

一、前言

之前一段时间做springboot项目的数据库的操作是使用JDBC进行的,非常的繁琐,当时自己app端使用的就是封装好的orm模型,然后找到了mybatis-plus,很容易上手,但是当时是初学,摸清基本原理还是花了不少时间,当时的主要参考资料就是plus作者的官方文档地址

本文主要适用于那些从未接触过后端数据库操作,想要快速完成后端开发任务的朋友

二、配置

1.依赖配置

在gradle下添加以下语句完成mybatis-plus的集成

implementation "com.baomidou:mybatis-plus-boot-starter:3.4.2"

如果使用的是maven进行开发也比较容易的进行转换,基本上没有难度

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.1</version>
</dependency>

2.基本属性的配置

spring.datasource.url=jdbc:mysql://localhost:3306/数据库名
spring.datasource.username=用户名
spring.datasource.password=用户密码
//驱动名称
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

//mybatis-plus方面的配置
//当然还有好多配置,这里只配置最基本的
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
mybatis-plus.global-config.banner=true

3.建立数据库

这部分由于是之前建好的数据库,就没有利用代码进行建库了,有兴趣可以参考官方文档的建库操作

4.建立映射bean

这部分,可以自己用相关的插件完成bean的创建,我这里使用的是kotlin的data类一行即可完成bean的搭建

data class City(val name:String, val state:String)

5.建立映射的mapper

着部分需要进行继承基类baseMapper,然后无需配置mapper的xml文件

interface FundMapper:BaseMapper<City> {
}

这部分要完成mapper的自动扫描需要在application上添加自动扫描的注解

//这部分与mapper的创建位置有关
//这里即在包名的路径下完成mapper包的建立,然后扫描的都是mapper包下的mapper
@MapperScan("包名.mapper")

6.乐观锁的添加

这个需要在包名下创建一个config的包,包下添加配置类,着部分采用kotlin进行编写,fun即方法名,翻译成Java应该没有难度

@Configuration
class MybatisPlusConfig {
    @Bean
    fun mybatisPlusInterceptor(): MybatisPlusInterceptor {
        val interceptor = MybatisPlusInterceptor()
        //添加乐观锁插件
        interceptor.addInnerInterceptor(OptimisticLockerInnerInterceptor())
        return interceptor
    }
}

至此配置已经完全结束了,下面开始介绍使用

7.配置自动装载机制

这部分和官方的稍微不一样,Kotlin这边貌似只支持@Resource注解,@Autowire注解使用不了

@Resource
lateinit var cityMapper:CityMapper

如果是Java的话使用以下方式完成

@Autowired
private CityMapper cityMapper;

三、注解的使用

1.默认注解

使用默认注解需要接受mybatis-plus的规范,首先数据库字段必须以下划线作为单词的分隔,映射的类使用myName这种驼峰式的写法

//类似
myName需要写成my_name

默认注解有常用的insert,delete,update,还有默认查询全部的selectList

  • insert

cityMapper.insert()

  • delete

cityMapper.delete()

  • update

这方面由于没有使用它提供的注解进行建表导致,不能直接使用,需要使用下面即将要讲的QueryWapper

//第一个是更新的对象,第二个是条件

cityMapper.update(city,queryWrapper)

2.自定义sql语句的注解

这部分需要在mapper里面进行编写相关的sql语句

interface FundMapper:BaseMapper<City> {
    @Select("select * from city")
    fun selectAll():List<City>
    
    //如果是带参数的
    @Select("select * from city where name = #{name}")
    fun selectPart(@Param("name")name:String):List<City>
    
    //其他的注解,类似update,delete等等都是一样的道理
    
    //如果是选择部分列,返回值只需要设置好相关bean即可,这里做示范是相同的,自己可以自定义返回的bean
    @Select("select name,state from city")
    fun part():List<City>
}

3.使用

使用就很简单了,操作jdbc mybatis-plus已经帮你做好了

@Resource
lateinit var cityMapper: FundMapper
@GetMapping("/search")
fun searchCity():String{
    val cityList = cityMapper.selectPart("us")
}

4.需要注意的

这个踩过坑,如果是bean有默认值值记得与数据库的顺序相同,不然就会出现类型不匹配的问题,当时找了好久的原因,如果不想考虑这些事,建议bean全部采用String类型的进行处理,这样只需要转换完成值的变换,如果没有默认值的话是正常的

四、QueryWapper的使用

这个QueryWapper封装了常用的操作,类似等于,大于等等的条件,有时候很方便,不需要编写mapper,主要是配合一些默认注解的条件的,类似update,更多使用可以见官网的详细介绍

val queryWrapper = QueryWrapper<City>()
queryWrapper
	.eq("name","us")
cityMapper.update(city,queryWrapper)

五、总结

通过以上的讲解,你可以获得基本的数据CRUD的能力,告别jdbc的繁琐操作,如果想要深入学习,上面这些介绍是远远不够的,希望对大家初步学习mybatis-plus有帮助。

原文地址:https://cloud.tencent.com/developer/article/2059532

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


所以很多人都会选择将这些生活琐事来交给智能化产品,在众多产品中,扫拖机器人所给我们带来的便利性最强,扫地、拖地全都一气呵成,不需要人为过多干预,不过目前大多数扫拖机器人对于双手解放得不彻底。而石头作为
“昨天的经历都将成为明天的力量。” 将绝大部分精力都奉献给璃月港的刻晴,可以说是《原神》中的高人气角色了,虽然是常驻角色,并且对于普通玩家来说……刻师傅别刮了……不过作为开服就存在的角色,还有独特的剑法
最近,全球知名的通信产业盛会MWC 2024(2024世界移动通信大会)正式召开,其中,联发科以“连接AI宇宙”(Connecting the AI-verse)为主题,为大众展示出一系列在AI和移动通信技术等领域的最新突破,吸引了大量行业
今年上半年有很多值得关注的机型,其中华为最新的影像旗舰华为P70 Art也自然受到了业界不少的关注目光,目前关于这款机型的轮廓图已经在网上曝光。
目前,2024世界移动通信大会(MWC)正在西班牙巴塞罗那举行,值得一提的是,此次大会参展中国厂商非常多,包括华为、中兴、小米、荣耀等等多家厂商均在其列。
就在去年,真我推出了11 Pro+,用一个2亿像素传感器和zoom变焦功能,开启了中端手机影像的长焦大战,而后友商才姗姗来迟的跟进了2亿像素传感器。
【手机之家新闻】一年一度的MWC已经于当地时间2月26日在巴塞罗那正式开展,在本次MWC2024上全球各大厂商齐聚一堂,展出自家最新的技术与产品,其中中兴就参展本次MWC2024,并且展出了诸多面向企业端的产品,而旗下的
近日,联发科在MWC 2024(2024 世界移动通信大会)上展出了一系列令人瞩目的AI和移动通信技术突破,以“连接AI宇宙”(Connecting the AI-verse)的展厅吸引了无数业界精英和媒体的目光。特别是其现场的生成式AI技术
虽然目前国内已经有不少厂商入局折叠屏产品,但是努比亚却迟迟没有入局。不过在近日举办的MWC 2024展会上,努比亚发布了自家首款折叠屏手机——努比亚Flip,预计国内很快也会上市。
MWC 2024正在西班牙巴塞罗那举办,和往年一样,荣耀这次依旧携众多新产品、新技术参会。荣耀Magic6 Pro、荣耀Magic V2 RSR保时捷设计的机型在海外正式发布,并且还展示了魔法大模型、任意门等诸多新技术。
MWC 2024正在西班牙巴塞罗那如火如荼地举行,其中小米也参加了今年的大会,在会上发布了在国内大受欢迎的小尺寸旗舰——小米14。值得一提的是,高通公司CEO安蒙甚至亲临发布会现场为这款机型助阵。
《原神》是一直以来在机圈深受欢迎的游戏,在充满幻想的提瓦特大陆上,你可以邂逅不少性格迥异、能力独特的伙伴。而一加Ace系列一直就拥有非常强烈的电竞属性,也是畅玩《原神》的热门机型,而在本月,一加Ace 3将推
有不少网友发现,今年新机的发布时间相对于往年大幅提前,很多厂商在春节之前密集发布了自己最新的中高端机型,给人一种年后没什么新机可发了的感觉。不过魅族全新的大杯机型——魅族21 PRO非常值得期待,魅族科技也
2022年7月,小米12S Ultra正式发布,这款产品率先将1英寸大底主摄引入到移动影像领域,同时凭借鲜明的徕卡影调给人留下深刻的印象,同时这款产品也被视为了影像旗舰地位的机型。如果从那时算起,到现在差不多已经快过
随着智能手机的日益普及和智能化进程的加速,智能穿戴设备成为了人们关注的焦点。各大智能手机厂商纷纷进军智能穿戴市场,试图在这一新兴领域抢占先机。
早在去年秋天,HyperOS操作系统发布的时候,小米便勾勒出了“人车家全生态”的美好蓝图,而在这其中,小米的多终端统一战略是核心,目前已经有不少小米产品预装或者接受到了HyperOS操作系统的推送,在过去几个月的时
今年雷军将把更多的精力放在小米汽车上,所以接下来的手机业务将由刚刚兼任小米品牌总经理卢伟冰接管。同时雷军也在微博上表示小米2024年开年旗舰——小米14 Ultra即将在近期发布,并且将有卢伟冰进行讲解。另外,卢
新的一年有龙则灵,有愿必达。自1月19日起,荣耀加码“新年荣耀,一起成龙”年货节,在全国荣耀线下门店上线了“新年许愿处”、“龙运当头”等趣味活动,吸引大批消费者到店打卡许愿,戴龙头迎好运。与此同时,为了回
小米在官网微博中已经透露了关于小米14 Ultra信息,所以新机上市应该不会太晚。根据德国莱茵的官方消息,目前小米14 Ultra(型号为24030PN60G)获得了莱茵无频闪认证,表明这款手机可以有效减轻屏幕给用户带来的视觉疲
2月22日,上海广播电视台与华为举办鸿蒙合作签约仪式,宣布其官方客户端看看新闻APP将基于HarmonyOS NEXT鸿蒙星河版启动鸿蒙原生应用开发,为用户提供更加极致的新闻资讯服务体验。此次合作标志着上海广播电视台成为全国