目录
1.命名规则
1.resultMap(对应类属性名称与数据库字段名称)
2.多表查询(ResultMap)
1.创建articleInfo类
2.创建ArticleMapper.xml配置文件和ArticleMapper接口
①:不建议使用 (文件之间耦合严重)
②常用的写法(将文件之间尽可能的解耦)
3.动态sql
1.
2.
3.
①在where后面加1=1
②使用标签
4.
5.
还有一个问题,在上面代码中我们数据库字段的命名和Java类中的命名是一一对应并且相等的
但是在我们实际开发中,数据库字段和Java的命名规则并不相同
那么我们应该如何将他们对应起来呢?
我们设置Java类中的userName,和passWord字段与数据库中的名称不一样,
此时我们使用resultMap来将他们一一映射起来(只需要映射字段名称不相同的即可)
测试查询方法:
结果如下:
可以看到虽然数据库字段名称与Java类中的属性名称不一样,但是我们通过resultMap查询到了数据
一般项目中很少用,因为写法复杂,并且运行效率不高,交给数据库去实现,时间不可控
对性能要求高的项目几乎不会用,尤其是面向用户的项目
比如:根据文章id获取文章相关信息,然后根据作者id获取作者信息
@Data
public class ArticleInfo {
private Integer id;
private String title;
private String content;
private Date createtime;
private Date updatetime;
private Integer rcount;
// 作者相关信息
private User user;
}
在ArticleMapper接口写方法:
根据文章id获取文章相关信息,然后根据作者id获取作者信息
xml中代码
查询到了结果
在文章类中只把我们需要的字段传入进来
在xml文件中传属性即可
可以看到同样是查询到了结果,但是这个方法比起刚才的方法,不需要去调用另一个xml文件里的代码,将两个xml文件解耦,我们在写项目的时候一定要尽量避免文件之间耦合
那么如果我们只传一部分数据呢?
比如我们之传入题目和用户id,来测试一下:
那么我们应该如何解决呢?
我们使用if标签如果用户传入数据,就设置成用户传入的数据,如果没有传入数据,就设置为默认值或者null
如果所有字段都可以不传数据呢?那我们把全部字段使用
显而易见,如果有用户第一个数据不传或者最后一个数据不传,那么逗号的位置我们没办法放置,有可能会多一个逗号,此时我们就可以使用另外一个标签
这样就可以解决逗号放置的问题了,
注意如果什么都不填写,还是会报错的,但是这个场景不太符合实际,因为什么都不填,那也不需要插入数据了,这种情况在前端就直接pass了,也不会传到后端来
我们在购物的时候,经常会去筛选一些条件,这样的动态sql语句应该如何拼接呢?
此时我们传入两个参数
发现查询到了结果
那如果我们之传入第二个参数呢?
报错了,where后面直接跟的是and,第一个数据不传,结果where和and中间的数据没有了,造成sql语句报错,那么该如何解决呢?
这样1=1在第一条语句,就不用担心第一条语句为空的情况了
他会自动的为我们添加合理的and,并且如果后面没有数据传入,它会将where关键字也去掉
此时我们不传第一条数据,也运行成功了
一条数据也不传,也运行成功了
当我们更新多个字段的时候,也会发生与where同样的情况
所以我们直接使用
批量操作的时候 ,比如批量插入,删除以及更新数据
例如:批量删除id2-4的数据
测试:
查看运行结果:
成功删除了id为2,3,的文字,因为id为4的文章不存在,所以只删除了两条数据
同理,添加,更新等批量操作都是如此,小伙伴们可以下来自己去试试,操作一下
到这里,我们mybatis的学习就告一段落啦~~我们下篇博客见~