常规写法,包括两个文件:
1.接口:方法的声明(给其他层调用(Service)调用)
2.XML: 实现接口
步骤:1.定义Mapper接口,
2.编写XML文件:namespace的内容要与之前定义的Mapper接口相对应。并在mapper里写SQL语句。
#{}与${}的区别:
1.#{}与JDBC的prepareStatement类似,先将该地方的值换位?,再把传过来的参数换位String类型变成一条完整的SQL语句应用于大多数场景;
2.${}是直接替换,其应用场景一般为类似于select * from userinfo order by id ${myorder}等可以直接替换的情况。
需要设置主键时,用useGeneratedKeys="true",表示设置主键,keyColumn:设置主键值在数据库表的属性名,keyProperty:设置表的属性名对应的类的属性名
注意:不能写成select * from userinfo where username like '%#{username}%',因为#{},会先用?代替此处的值,然后把传过来的变量变为String类型,导致变为:select * from userinfo where username like '%'username'%',无法通过。解决方法:
1.可以通过concat方法将'%','#{username}','%'拼在一起。
2.也可以直接写为select * from userinfo where username like '%${username}%'。
类中的属性和数据库表中的字段名不一致时,那么查询的结果为null,解决方案:
1.将类中的属性和数据库表中的字段名保持一致。
2.使用sql语句中的as进行列名(字段名)重命名,让列名(字段名)等于属性名。
3.使用ResultMap,属性名和字段名进行手动映射(最好全部都设好,防止多表查询时出问题),column是数据库的字段名,property是定义的类的属性名。
在相应的sql字段里设置ResultMap。
新版本写法:只需要注解。
注解里的内容就是常规写法对应sql标签里的内容。
出现动态sql的原因:在数据库中null不等于空。
语法:
...
属性:prefix:表示整个语句块,以prefix的值作为前缀(里面的东西加在标签内的内容之前)
suffix:表示整个语句块,以suffix的值作为后缀(里面的东西加在标签内的内容之后)
prefixOverrides:表示整个语句块要去除的前缀
suffixOverrides:表示整个语句块要去除的后缀
suffixOverride的作用在于如果最后一个变量等于null,则不执行
属性:
collection:绑定方法参数中的集合,如List,Set,Map或数组对象
item:遍历时的每一个对象
open:语句块开头的字符串
close:语句块结束的字符串
separator:每次遍历之间间隔的字符串。