ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

MyBatis-Plus入门案例:查询数据库中所有记录

2022-03-03 10:01:56  阅读:363  来源: 互联网

标签:查询数据库 mybatis Plus mysql MyBatis plus com


https://guoqianliang.blog.csdn.net/article/details/115368094

MyBatis-Plus在MyBatis的基础上只做增强,不做改变,目的是为了简化开发,提高效率。本专栏六篇文章围绕MyBatis-Plus的常用技术点,结合springboot,实现了对数据库记录的CRUD操作,其他文章请参考:

《MyBatis-Plus入门案例:查询数据库中所有记录》
《MyBatis-Plus添加:常用主键策略的分析及实现》
《MyBatis-Plus更新:自动填充与乐观锁的实现》
《MyBatis-Plus查询:批量、条件、分页查询的实现》
《MyBatis-Plus删除:物理删除与逻辑删除的实现》
《MyBatis-Plus高级查询:条件构造器的实现》
作者:Hudie
个人公众号/CSDN博客:编程一只蝶
项目已开源至gitee:https://gitee.com/guo-qianliang/mybatis-plus-test
项目已开源至github:https://github.com/Guoqianliang/mybatis-plus-test

文章目录
MyBatis-Plus入门案例:查询数据库中所有记录
步骤1:创建数据库和表
步骤2:创建springboot工程并引入依赖
(1) 创建springboot工程
(2) 创建User实体类
(3) 引入mybatis-plus和mysql的依赖
步骤4:配置数据库信息
✔ 探讨关于jdbc版本的选择问题
步骤5:继承BaseMapper接口(核心)
开始测试
流程分析:通过日志查看底层sql源码
MyBatis-Plus入门案例:查询数据库中所有记录
步骤1:创建数据库和表
首先在数据库中创建名为MyBatis_plus的数据库。然后在该数据库中创建一张user用户表,并添加几行数据:

// 创建user表
CREATE TABLE USER
(
    id BIGINT(20)NOT NULL COMMENT '主键ID',
    NAME VARCHAR(30)NULL DEFAULT NULL COMMENT '姓名',
    age INT(11)NULL DEFAULT NULL COMMENT '年龄',
    email VARCHAR(50)NULL DEFAULT NULL COMMENT '邮箱',
    PRIMARY KEY (id)
);


// 向user表添加数据
INSERT INTO USER(id, NAME, age, email)VALUES
(1, 'Jone', 18, 'test1@qq.com'),
(2, 'Jack', 20, 'test2@qq.com'),
(3, 'Tom', 28, 'test3@qq.com'),
(4, 'Sandy', 21, 'test4@qq.com'),
(5, 'Billie', 24, 'test5@qq.com');


步骤2:创建springboot工程并引入依赖
(1) 创建springboot工程
使用Spring Initializr创建springboot工程,这里设置mybatis-plus-test为工程名。
本次实验使用springboot2.2.1版本。


(2) 创建User实体类
另外,需要在项目中创建User实体类与数据库中的User表对应:

import lombok.Data;
@Data
public class User {
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

(3) 引入mybatis-plus和mysql的依赖
下面的pom代码中,给出了3个依赖,分别是mybatis-plus、mysql驱动、lombok。其中的lombok必须配合插件使用,主要是为了简化实体类的编写,因为其可以通过注解来自动生成getter和setter方法。

        <!--mybatis-plus-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.3.1</version>
        </dependency>
        <!--mysql依赖-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <!--lombok用来简化实体类(自动生成getter和setter方法)-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>


步骤4:配置数据库信息
在 application.properties 配置文件中添加数据库相关配置:

spring boot 2.0(内置jdbc5驱动)配置方式,本项目不使用。

#mysql数据库连接
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://[ip地址]:3306/mybatis_plus?characterEncoding=utf-8&useSSL=false
spring.datasource.username=root
spring.datasource.password=[xxxx]

spring boot 2.1及以上(内置jdbc8驱动),本项目使用springboot2.2.1,所以选择这种配置方式。

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://[ip地址]:3306/mybatis_plus?serverTimezone=GMT%2B8
spring.datasource.username=root
spring.datasource.password=[xxxx]

✔ 探讨关于jdbc版本的选择问题
jdbc8.0版本的jdbc驱动的url需要添加 ?serverTimezone=GMT%2B8后缀,否则会出现报错。另外,在jdbc8.0中也建议使用com.mysql.cj.jdbc.Driver这个驱动来代替com.mysql.jdbc.Driver,否则可能会出现运行报错的情况。

步骤5:继承BaseMapper接口(核心)
继承BaseMapper接口后,无需编写 mapper.xml 文件,即可获得CRUD功能。



开始测试
@SpringBootTest
class MybatisPlusTestApplicationTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void findAll() {
        List<User> users = userMapper.selectList(null);
        System.out.println(users);
    }
}


上面这条查询语句执行后,成功遍历出了数据库中的信息:


流程分析:通过日志查看底层sql源码
通过配置下面一条语句,可以实现,在执行时显示底层sql源码的功能,便于后期排查问题,了解即可。

# 查看mybatis日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl



至此,MyBatis-Plus入门案例之查询数据库中所有记录的操作就完成了!可以发现,我们即没有写sql语句也没有写xml配置文件,只是让接口继承了Basemapper,然后直接调用了方法而已。
————————————————
版权声明:本文为CSDN博主「Hudie.」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_43691058/article/details/115368094

标签:查询数据库,mybatis,Plus,mysql,MyBatis,plus,com
来源: https://www.cnblogs.com/jianershisan/p/15958370.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有