文章目录
- 一、MybatisPlus
- 1、ORM
- 2、添加依赖
- 3、全局配置
- 4、Navicat
- 5、UserController
- 6、CRUD操作
- 7、BaseMapper
- 8、两个注解
- 二、多表查询
- 1、模拟用户订单
- 2、通过用户查相关订单
- 3、UserMapperNew
- 4、查询订单和所属用户
- 5、OrderMapper
- 6、OrderController
- 三、条件查询
- 四、分页查询
一、MybatisPlus
1、ORM
(Object Relational Mapping)对象关系映射,为了解决面向对象与关系数据库存在的互不匹配的一种技术
ORM框架本质是简化编程中操作数据库的编码
2、添加依赖
<!-- MyBatisPlus依赖--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.2</version></dependency>
<!-- mysql驱动依赖--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.32</version></dependency>
<!-- 数据连接池druid--><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.23</version></dependency>
3、全局配置
在application.properties中添加配置
server.port=80
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3307/demo2?useSSL=false
spring.datasource.username=root
spring.datasource.password=123456
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
😮由于我PC有两个数据库版本的存在,所以这里使用3307端口不产生冲突,数据库的名称为demo2,账号密码默认
在启动项,也就是
项目名Application
中添加@MapperScan注解,这里是新建的mapper包,如果不好找路径,那么鼠标右键点击包,选择Copy Path/Reference...
复制路径
4、Navicat
在navicat里面把表建好,然后选择id主键自增
5、UserController
这里模拟查询用户
之前的实体类User继续使用
编写UserMapper接口:
编写UserController,并且声明UserMapper对象,写上@AutoWired注解表示注入,这样我们可以直接使用UserMapper中的方法🤓
🌐浏览器测试一下:
😈如果查询不到报错:检查数据库是否正常连接
也可以在控制台日志看到结果:
6、CRUD操作
同理,有查就少不了指定id查、增删改
查询指定用户:
UserController:
UserMapper:
增删改UserController:
增删改UserMapper:
🌍打开ApiPost测试一下:
这里id是8虽然是自增,因为我之前测试过几条,我们可以再加一条:
可以看到表更新了😀
😈如果表中的username是???说明是编码的问题,在navicat中设置utf-8字符集还没用的话,继续在application.properties
中的url后多加点规则
spring.datasource.url=jdbc:mysql://localhost:3307/demo2?useSSL=false&useUnicode=true&characterEncoding=utf-8
😈如果出现Data truncated for column id at row 1
问题,①检查实体类参数类型是否和数据库表中匹配
②将数据库表的int范围调高
③看看是不是id默认在表里面排最后了,把id上移到第一条和mapper中语句参数对应😲
7、BaseMapper
白学时刻,以上都是我们在mybatis中用到的,而mybatisPlus提供了BaseMapper接口
新建UserMapperNew接口:
修改UserController类,可以发现userMapperNew里面就自带了很多方法,可以ctrl+左键
点进去详情查看:
List<User> list = userMapperNew.selectList(null);
重新测试一下 🤓
剩下方法类似👍
8、两个注解
@TableName注解说明了对应哪一张表,应对实体类和表不一致
@TableId主键自增,在控制台打印日志时看到对应的id(之前会显示0)
二、多表查询
实现复杂关系映射,可以使用@Results、@Result、@One、@Many注解组合完成复杂关系的配置
1、模拟用户订单
navicat 新建订单order表(uid表示所属哪个用户订单):
2、通过用户查相关订单
在User类里添加代码,其实orders这个东西是不在user表里的,所以这样打上注解,并且添加getter和setter方法,只是为了实现多表查询😮
在UserMapperNew中定义查找用户和订单的接口:
在UsrController中调用:
🌍浏览器访问,发现orders为空(因为本来user表中就没有orders)
3、UserMapperNew
利用@Results、@Result和@Many注解
//查询用户及其所有的订单@Select("select * from user")@Results({@Result(column = "id",property = "id"),@Result(column = "username",property = "username"),@Result(column = "password",property = "password"),@Result(column = "birthday",property = "birthday"),@Result(column = "id",property = "orders",javaType = List.class,many=@Many(select = "com.example.demo.mapper.OrderMapper.selectByUid"))})List<User> selectAllUserAndOrders();
这里是将结果集对应起来,然后利用user表中的id,去映射orders,说明orders的参数类型List,many表示一对多的关系;UserMapperNew去使用OrderMapper中的方法😮使得user表的id能够作为order表的uid去执行sql语句
😈刚开始我报错说是语法问题,检查后无误,又将包全部导入一遍,还是爆500错误;发现可能是关键字冲突,将order表的名字改为t_order后成功运行
4、查询订单和所属用户
同理,在Order实体类加上注解,说明user参数并不存在
@TableField(exist = false)private User user;
5、OrderMapper
// 查询所有的订单,同时查询订单所属的用户@Select("select * from t_order")@Results({@Result(column = "id",property = "id"),@Result(column = "orderTime",property = "orderTime"),@Result(column = "money",property = "money"),@Result(column = "uid",property = "uid"),@Result(column = "uid",property = "user",javaType = User.class,one=@One(select = "com.example.demo.mapper.UserMapperNew.selectById"))})List<Order> selectAllOrdersAndUser();
这里是一个订单只对应一个用户,所以是@One注解,利用订单的uid对应找出user表中的用户
6、OrderController
新建OrderController控制器,运行
@RestController
public class OrderController {@AutowiredOrderMapper orderMapper;@GetMapping("/order/findAll")public List<Order> find(){return orderMapper.selectAllOrdersAndUser();}
}
可以看到三个订单以及所属的用户都被查询出来了 🤓
三、条件查询
前面说过MybatisPlus对单表查询增强了,我们可以不用自己写sql语句,这里采用QueryWrapper
UserController,表示我们只想找到关于火男的信息:
// 条件查询@GetMapping("/user/find")public List<User> findByCondition(){QueryWrapper<User> queryWrapper = new QueryWrapper();queryWrapper.eq("username","火男");return userMapperNew.selectList(queryWrapper);}
四、分页查询
UserController:
// 分页查询@GetMapping("/user/findByPage")public IPage findByPage(){
// 设置起始值和每页条数Page<User> page = new Page<>(0, 2);IPage iPage = userMapperNew.selectPage(page,null);return iPage;}
可以在mybatis-plus官网查看page使用方法:
edge运行结果默认返回JSON格式,如果其他的浏览器可以用F12
查看具体参数: