Mybatis-CRUD

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

首先,建立数据库mybatis和表user
并在IDEA中连接数据库
在这里插入图片描述
在这里插入图片描述

一个简单的基于Mybatis程序实现CRUD
程序结构:在这里插入图片描述
具体的程序:
在这里插入图片描述
获得sqlSession
SqlSession 完全包含了面向数据库执行 SQL 命令所需的所有方法。
在这里插入图片描述
接口和Mapper类型的方法实现
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
根据Junit写测试用例,测试方法实现—差
在这里插入图片描述
其实第二行也是固定的格式,每个userMapper都调用一个业务。
增改:
在这里插入图片描述
删:
在这里插入图片描述
执行CRUD操作后,数据库的内容也会改变。
执行前的数据库:
在这里插入图片描述
删除id为4的记录:—执行后:
在这里插入图片描述

万能Map

假设,我们的实体类,或者数据库中的表,字段或者参数过多,我们应当考虑使用Map
注:现在我只知道这个Map能用,但是不清楚他的优势在哪里。可能以后项目中就该明白了,现在先理解它的使用即可。

接口中定义方法addUser2,传入一个 map,而不是user
在这里插入图片描述
xml中的方法实现,传入的是map键值对中的key
在这里插入图片描述
Junit测试,注意这里map中的key和上边xml中传入的参数一致。
在这里插入图片描述
Map传递参数,直接在sql中取出key即可! 【parameterType=“map”】

对象传递参数,直接在sql中取对象的属性即可!【parameterType=“Object”】

只有一个基本类型参数的情况下,可以直接在sql中取到!

多个参数用Map,或者注解!

模糊查询怎么写?
  1. Java代码执行的时候,传递通配符 % %
List<User> userList = mapper.getUserLike("%李%");
  1. 在sql拼接中使用通配符!
  select * from mybatis.user where name like "%"#{value}"%"

这里复习一下SQL注入

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值