Mybatis(二)

岁酱吖の 提交于 2020-02-23 00:12:24
动态sql
查询的时候如果某些条件没带可能sql拼装会有问题,解决:
  • 1.where 1=1
  • 2.mybatis使用where标签将所有的查询条件包括在内,mybatis会将where标签中拼装的sql 多出来的 and 或 or 去掉
    where只会去掉第一个多出来的and和or,后面多出来的and和or不能解决
//动态sql标签
<if test=""></if>
//prefix:前缀,trim标签体中是整个字符串拼串后的结果
//prefixOverrides:前缀覆盖,去掉整个字符串前面多余的字符
//suffix:后缀,给拼串后的整个字符串加一个后缀
//suffixOverrides:后缀覆盖,去掉整个字符串后面多余的字符
<trim prefix="where" prefixOverrides="" 
		suffix="" suffixOverrides="">
</trim>
<choose>
	<when test=""></when>
	<otherwise></otherwise>
</choose>
<foreach></foreach>//可用来批量保存

mybatis默认还有两个内置参数
-parameter:代表整个参数

  • 单个参数:_parameter就是这个参数
  • 多个参数:参数会被封装为一个map,_parameter就是代表这个map

_databaseId:如果配置了databaseIdProvider标签,databaseId就是代表当前数据库的别名

增删改同级标签sql,可抽取可重用的sql片段,方面后面引用
  • sql抽取,将要查询的列名或者插入用的列名抽取出来方便引用
  • include来引用抽取的sql
  • include还可以自定义一些property,sql标签内部就能使用自定义的属性
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!