MyBatis的使用

一.在创建Spring项目时引入MyBatis Framework和MySQL Driver;

二.下载插件:MyBatisX插件。

三.配置文件:

四.根据MyBatis写法完成数据库的操作

     常规写法,包括两个文件:

      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}等可以直接替换的情况。

删除语句:<delete>,只需填写id即可。id为对应的Mapper类里的对应的方法名。

修改操作:<update>,只需填写id即可。id为对应的Mapper类里的对应的方法名。在set属性值时,用#{}可以直接写对应的类的属性名,不必写类名.get属性名()。

添加语句:<insert>,只需填写id即可。id为对应的Mapper类里的对应的方法名。

需要设置主键时,用useGeneratedKeys="true",表示设置主键,keyColumn:设置主键值在数据库表的属性名,keyProperty:设置表的属性名对应的类的属性名

 查询语句:用<select>标签,id填写对应Mapper接口对应的方法,resultType写定义的接收对应sql数据的model类的位置。

like查询:

注意:不能写成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:

出现动态sql的原因:在数据库中null不等于空。

<if>标签:

语法:

<if test="条件(类似于if条件()里的语句)">

...

</if>

<trim>标签

属性:prefix:表示整个语句块,以prefix的值作为前缀(里面的东西加在标签内的内容之前)

           suffix:表示整个语句块,以suffix的值作为后缀(里面的东西加在标签内的内容之后)    

           prefixOverrides:表示整个语句块要去除的前缀

           suffixOverrides:表示整个语句块要去除的后缀

suffixOverride的作用在于如果最后一个变量等于null,则不执行<if>里的内容,会导致sql语句在最后多了个逗号进而无法执行。

<where>:

<where>标签的存在是因为如果直接写成where+<if>的组合,若<if>内的条件不满足,无法执行,就会因为多一个where而使sql无法执行。<where>标签可以根据<where>标签中的内容决定是否生成"where"关键字,去除最前面的"and"关键字。

<set>:

<set>标签可以根据<set>标签中的内容决定是否生成"set"关键字,去除最后面的","。可与<trim prefix="set"  suffixOverrides=",">替换。

<foreach>:

属性:

collection:绑定方法参数中的集合,如List,Set,Map或数组对象

item:遍历时的每一个对象

open:语句块开头的字符串

close:语句块结束的字符串

separator:每次遍历之间间隔的字符串。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值