• 博客园logo
  • 会员
  • 周边
  • 新闻
  • 博问
  • 闪存
  • 众包
  • 赞助商
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
风吹花落泪如雨
博客园    首页    新随笔    联系   管理    订阅  订阅

MyBatis学习(三)-----增删改查

一、增删改

1、在接口定义方法

2、在xml映射文件实现

3、代码测试

 

二、获取自增主键和非自增主键的值

自增主键

非自增主键

 

三、参数处理

1、单个参数:mybatis不做特殊处理,直接#{参数名}取出参数值

2、多个参数:多个参数被封装成map。使用#{param1}、#{param2}按顺序取出map里的参数

3、命名参数:@Param("id"),可使用#{id}取出map里的参数

4、POJO:如果多个参数是我们业务逻辑的数据模型,可以直接传入POJO,#{属性名}取出对应的参数值

5、Map:如果不是,为了方便,也可以传入map。

6、To:如果不是业务模型中的数据,但是经常要使用,推荐来编写一个TO(Transfer Object)数据传输对象

 

四、#和$取值区别

区别: #{}:是以预编译的形式,将参数设置到sql语句中,PreparedStatement,防止sql注入

      ${}:取出的值直接拼装到sql语句中,会有安全问题

      原生jdbc不支持占位符的地方我们就可以使用${}进行取值:分表from ${year}_salary、排序order by ${f_name} ${order]

#{}更丰富用法:

   如果一个列允许 null 值,并且会传递值 null 的参数,就必须要指定 JDBC Type:

   在我们数据为null的时候,有些数据库可能不能识别mybatis对null的默认处理(other),比如Oracle(报错)

   由于全局配置中:jdbcTypeForNull=OTHER;oracle不支持:

  1、

  2、

 

五、返回List

 

六、记录封装map

1、编写接口方法

2、在xml映射文件实现

 

七、自定义结果映射规则resultMap(MyBatis 最强大的特性)

resultMap和resultType只能任选其一:

posted @ 2018-08-26 11:02  风吹花落泪如雨  阅读(83)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2026
浙公网安备 33010602011771号 浙ICP备2021040463号-3