- 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,或者注解!
模糊查询怎么写?
- Java代码执行的时候,传递通配符 % %
List<User> userList = mapper.getUserLike("%李%");
- 在sql拼接中使用通配符!
select * from mybatis.user where name like "%"#{value}"%"
这里复习一下SQL注入