MyBatis

一、注解@param 参数绑定、map绑定/ Map集合

@Param这个注解是用来解决接口方法有多个参数时、xxMapper.xml文件绑定参数混淆问题。需要在DAO方法形参前面添加@Param(“xxx”),来区分不同的需要绑定xxMapper.xml的参数。注意双引号里的值要与xxMapper.xml中#{}中的值相等,如:

DAO方法:public void list (@Param(“abc1”) String abc1, @Param(“abc2”) String abc2);
xxMapper.xml中:values(#{undefinedabc1},#{abc2}

可以修饰JavaBean对象、Map集合等

public void list (@Param(“param”) User user);
xxMapper.xml中:where username = #{param.userName}

List getUser(@Param(“param”) Map map);
xxMapper.xml中values:(#{param.id},#{param.name},#{param.age},#{param.sex})二、

二、mybatis中 连接池

使用德鲁伊连接池

<properties resource="jdbc.properties"/>
<typeAliases>
<!-- 实体类的别名包扫描,别名就是默认当前类名,不区分大小写 -->
<package name="com.qf.pojo"/>
</typeAliases>
<!-- 环境配置 -->
<environments default="mysql">
<environment id="mysql">
<transactionManager type="JDBC"/>
<!-- 启用mybatis自带的连接池 -->
<!--  <dataSource type="org.apache.ibatis.datasource.pooled.PooledDataSourceFactory"> -->
<!-- 不启用mybatis连接池 -->
<!--  <dataSource type="org.apache.ibatis.datasource.unpooled.UnpooledDataSourceFactory"> -->
<!-- 使用自己的连接池:自定义一个工厂类 继承了 mybatis里面的PooledDataSourceFactory -->
<dataSource type="com.qf.datasource.MyDruidDataSourceFactory">
<property name="driverClass" value="${jdbc.driverClassName}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<!-- 最大激活数量 -->
<property name="maxActive" value="${jdbc.maxActive}"/>
</dataSource>
</environment>
</environments>

mybatis高级映射:resultMap

 resultMap里面就是可以将每一个字段和实体类的属性一一映射

使用场景

1)当实体类属性和字段不一样

2)  mybatis多表查询的时候可以用 

id:resultMap它的标识id
type:就是实体类的全限定名称/别名  (返回值类型)

配置主键字段: 表中主键字段 id 和 实体类的属性 id一致
            property:实体类的属性名称 stuId
            column:表中字段列的名称 主键id


<resultMap id="myMap" type="student">
<id property="stuId" column="id"/>
<!-- 普通字段和实体类的其他属性名称一一对应 -->
<result property="stuName" column="name"/>
<result property="stuAge" column="age"/>
<result property="stuAddress" column="address"/>
<result property="stuBirthday" column="birthday"/>
</resultMap>

三、动态SQL

动态 SQL 是 MyBatis 的强大特性之一

1、if

<select id="findAllUser" resultType="User">
  SELECT * FROM user
  WHERE name = ‘zhangsan’
  <if test="age != null">
    AND age = #{age}
  </if>
</select>

2、choose、when、otherwise

<select id="findAllUser"
     resultType="User">
  SELECT * FROM User WHERE state = ‘ACTIVE’
  <choose>
    <when test="title != null">
      AND title like #{title}
    </when>
    <when test="author != null and name != null">
      AND name like #{name}
    </when>
    <otherwise>
      AND featured = 1
    </otherwise>
  </choose>
</select>

3、sql片段

<sql id="allStudent">select * from  student</sql>
<include refid="allStudent"></include>

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值