• SpringBoot Mybatis问题收集


    1.在SpringBoot中打印mybatis中执行的sql

    其实在application.properties 文件下,添加一下配置即可:

    logging.level.org.springframework=WARN
    logging.level.org.spring.springboot.dao=DEBUG
    logging.file=logs/spring-boot-logging.log

    注意:其中logging.level.com.你的Mapper包=日志等级

    logging.level.com.shitou.huishi.domain.dataaccess=debug

    2.在mybatis中返回count这个方法的结果

     <select id="selectListByType" parameterType="com.shitou.huishi.domain.entity.BusinessMarketAffiliate" resultType="java.lang.Integer">
        select count(1) as num from tb_business_market_affiliate
        where busi_id=#{busiId,jdbcType=INTEGER}
        and data_key=#{dataKey,jdbcType=INTEGER}
        and data_type=#{dataType,jdbcType=VARCHAR}
      </select>

    resultMap="java.lang.Integer" 改成 resultType="java.lang.Integer" 

    3.在Mybatis中单个参数使用test判断

      <select id="selectByPcode" parameterType="java.lang.Integer" resultMap="BaseResultMap">
        select
        <include refid="Base_Column_List" />
        from tb_area_divisions
        where
        <choose>
          <when test="_parameter > 0">
            pcode = #{pcode,jdbcType=INTEGER}
          </when>
          <otherwise>
            level=1
          </otherwise>
        </choose>
    
      </select>

    注意语句中_parameter,使用pcode时会报错

    程序异常,nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'pcode' in 'class java.lang.Integer'

    但是单个参数和多参数的判断有个不同点,当我们的入参为entity实体,或者map的时候,使用if 参数判断没任何问题。

    但是当我们的入参为java.lang.Integer 或者 java.lang.String的时候,这时候就需要注意一些事情了

    首先入参是java.lang.Integer, 而不是map或者实体的入参方式,对于这类单个入参然后用if判断的,mybatis有自己的内置对象

    4.MyBatis报错 Parameter '0' not found. Available parameters are [arg1, arg0, param1, param2]

    这个问题跟mybatis的版本有关

    比如在mybatis3.4.0时 (mybatis-spring-boot-starter 1.1.1),#{0},#{1}都是可以使用的

    但是在mybatis3.4.6时(mybatis-spring-boot-starter 1.3.2),使用#{0},#{1}就不可以,就会报上述错误

    根据网上的描述,在mybatis3.4.4版本为边界,从MyBatis3.4.4版后不能直接使用 #{0} 要使用 #{arg0} ;

    5.parametertype 多个参数

    不写parameterType参数,但是不能改变参数顺序,也不能重复使用参数

    public List<XXXBean> getXXXBeanList(String xxId, String xxCode);  
    
    <select id="getXXXBeanList" resultType="XXBean">不需要写parameterType参数
    
      select t.* from tableName where id = #{0} and name = #{1}  
    
    </select>  

    2.基于注解,这个比较推荐

    public List<XXXBean> getXXXBeanList(@Param("id")String id, @Param("code")String code);  
    
    <select id="getXXXBeanList" resultType="XXBean">
    
      select t.* from tableName where id = #{id} and name = #{code}  
    
    </select>  

    https://blog.csdn.net/lixld/article/details/77980443

    6.模糊查询使用

    subject_name like '%${subjectName}%'

    或者

    subject_name like CONCAT('%',#{subjectName,jdbcType=VARCHAR},'%')

    https://blog.csdn.net/u010398771/article/details/70768280

    7.Mybatis语句中使用到大于小于

    mybatis查询的时候,需要用到运算符 小于号:< 和  大于号: >,在mybatis配置文件里面,这种会被认为是标签,所以解析错误

    解决方法:

    <if test="null!=beginTime and ''!=beginTime">
        <![CDATA[
           and create_time>=#{beginTime,jdbcType=VARCHAR}
    ]]>
      </if>
      <if test="null!=endTime and ''!=endTime">
      <![CDATA[
           and create_time<=#{endTime,jdbcType=VARCHAR}
             ]]>
      </if>

    用 <![CDATA[  ]]> 把sql语句包裹起来,注意不要 包裹<if这样的,必须只能包裹sql语句。

    8.Mybatis中使用in进行条件查询

    下面这种情况是将names作为map的其中一个参数进行传递的

    List<String> userNameList=new ArrayList<String>();

    Map<String,Object> map= ReflectUtil.beanToMap(request);
    map.put("userNames",userNameList);

     <if test="null!=userNames and userNames.size>0 ">
        and create_name in
        <foreach collection="userNames" index="index" item="item" open="(" separator="," close=")">
               #{item}
        </foreach>
      </if>

    必须对列表进行筛选,size必须大于0,不然直接就是create_name in,foreach条件查询为空,sql语句会报错!

    也可以自己手动拼接,然后使用${userNames}

    如果参数类型为list,则在使用的时候,collection属性必须指定为list

    查询方法:

    List<FolderImgInfo> selectListByImageIds(List<Integer> ids);

    Mybatis部分为:

    where 1=1
        <if test="null!=list and list.size>0 ">
          and id in
          <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
            #{item}
          </foreach>
        </if>

    9.使用Map进行参数传递:

    code:

    List<LoanOrder> getLoanOrderListForJDGL(Map<String,Object> map);

    xml:

      <select id="getLoanOrderListForJDGL" parameterType="java.util.Map" resultMap="BaseResultMap">
    
        select * from (
        select loan_order_id,loan_type,
        case loan_type
        when  1 then (select subject_no from hs_archive_info where archive_id=main_subject_archive_id)
        when  2 then (select subject_no from hs_archive_info where archive_id=borrower_archive_id)
        end subject_no,
        case loan_type
        when 1  then main_subject
        when 2 then borrower_name
        end subject_name,
        org_source,
        create_time,create_user_id, create_user_dept,create_name
        from hs_loan_order
        where loan_status=1
        order by create_time desc
        ) tb
        <where>
          1=1
          <if test="null!=productId">
            and loan_type=#{productId,jdbcType=BIGINT}
          </if>
          <if test="null!=loanOrderId and ''!=loanOrderId">
            and loan_order_id=#{loanOrderId,jdbcType=VARCHAR}
          </if>
          <if test="null!=subjectName and ''!=subjectName">
            and subject_name=#{subjectName,jdbcType=VARCHAR}
          </if>
          <if test="null!=subjectNo and ''!=subjectNo">
            and  subject_no=#{subjectNo,jdbcType=VARCHAR}
          </if>
          <if test="null!=createUserId and createUserId>0">
            and create_user_id=#{createUserId,jdbcType=BIGINT}
          </if>
          <if test="null!=departName and ''!=departName">
            and create_user_dept=#{departName,jdbcType=VARCHAR}
          </if>
          <if test="null!=beginTime and ''!=beginTime">
            <![CDATA[
           and create_time>=#{beginTime,jdbcType=VARCHAR}
    ]]>
          </if>
          <if test="null!=endTime and ''!=endTime">
            <![CDATA[
           and create_time<=#{endTime,jdbcType=VARCHAR}
             ]]>
          </if>
          <if test="null!=userNames and userNames.size>0 ">
            and create_name in
            <foreach collection="userNames" index="index" item="item" open="(" separator="," close=")">
              #{item}
            </foreach>
          </if>
    
        </where>
      </select>

    10.字符串数组入参,字符串数组出参:

     <select id="selectCountByOrderList" parameterType="java.util.List" resultType="java.lang.String">
        select order_id from hs_app_push
        <if test="null!=list and list.size>0 ">
          where order_id  in
          <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
            #{item}
          </foreach>
        </if>
      </select>

    方法:

    List<String> selectCountByOrderList(List<String> list);

     11.批量插入

     <insert id="insertBatchRecord" parameterType="java.util.List">
        <!--
          WARNING - @mbggenerated
          This element is automatically generated by MyBatis Generator, do not modify.
        -->
        <selectKey keyProperty="detailId" order="AFTER" resultType="java.lang.Long">
          SELECT LAST_INSERT_ID()
        </selectKey>
        insert into hs_excel_account_detail (batch_id, account_id, transaction_date,
        transaction_time, borrow_amount, loan_amount,
        currency, balance, opposite_account,
        opposite_name, digest, remark1,
        remark2, create_time, create_name
        )
        values
        <foreach collection ="list" item="item" index= "index" separator =",">
          (#{item.batchId,jdbcType=BIGINT}, #{item.accountId,jdbcType=BIGINT}, #{item.transactionDate,jdbcType=VARCHAR},
          #{item.transactionTime,jdbcType=VARCHAR}, #{item.borrowAmount,jdbcType=DECIMAL}, #{item.loanAmount,jdbcType=DECIMAL},
          #{item.currency,jdbcType=VARCHAR}, #{item.balance,jdbcType=DECIMAL}, #{item.oppositeAccount,jdbcType=VARCHAR},
          #{item.oppositeName,jdbcType=VARCHAR}, #{item.digest,jdbcType=VARCHAR}, #{item.remark1,jdbcType=VARCHAR},
          #{item.remark2,jdbcType=VARCHAR}, #{item.createTime,jdbcType=TIMESTAMP}, #{item.createName,jdbcType=VARCHAR}
          )
        </foreach>
      </insert>

     方法:

        void insertBatchRecord(List<ExcelAccountDetail> list);

    模板:

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <mapper namespace="com.shitou.huishi.domain.dataaccess.BusinessMarketAffiliateMapper">
      <resultMap id="BaseResultMap" type="com.shitou.huishi.domain.entity.BusinessMarketAffiliate">
        <id column="id" jdbcType="INTEGER" property="id" />
        <result column="busi_id" jdbcType="INTEGER" property="busiId" />
        <result column="data_type" jdbcType="VARCHAR" property="dataType" />
        <result column="data_key" jdbcType="INTEGER" property="dataKey" />
        <result column="data_value" jdbcType="INTEGER" property="dataValue" />
        <result column="create_name" jdbcType="INTEGER" property="createName" />
        <result column="create_time" jdbcType="TIMESTAMP" property="createTime" />
        <result column="update_name" jdbcType="INTEGER" property="updateName" />
        <result column="update_time" jdbcType="TIMESTAMP" property="updateTime" />
      </resultMap>
      
      <sql id="Base_Column_List">
        id, busi_id, data_type, data_key, data_value, create_name, create_time, update_name, 
        update_time
      </sql>
      
      <select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">
        select 
        <include refid="Base_Column_List" />
        from tb_business_market_affiliate
        where id = #{id,jdbcType=INTEGER}
      </select>
      
      <select id="selectListByLifeLoan" parameterType="java.lang.Integer" resultMap="BaseResultMap">
        select
        <include refid="Base_Column_List" />
        from tb_business_market_affiliate
        where data_type='life_of_loan' and busi_id=#{busiId,jdbcType=INTEGER}
      </select>
    
      <select id="selectListByType" parameterType="com.shitou.huishi.domain.entity.BusinessMarketAffiliate" resultType="java.lang.Integer">
    
        select count(1) as num from tb_business_market_affiliate
        where busi_id=#{busiId,jdbcType=INTEGER}
        and data_key=#{dataKey,jdbcType=INTEGER}
        and data_type=#{dataType,jdbcType=VARCHAR}
      </select>
    
      <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer" >
        delete
        from tb_business_market_affiliate
        where id = #{id,jdbcType=INTEGER}
      </delete>
    
      <insert id="insert" parameterType="com.shitou.huishi.domain.entity.BusinessMarketAffiliate">
        <selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
          SELECT LAST_INSERT_ID()
        </selectKey>
        insert into tb_business_market_affiliate (busi_id, data_type, data_key, 
          data_value, create_name, create_time, 
          update_name, update_time)
        values (#{busiId,jdbcType=INTEGER}, #{dataType,jdbcType=VARCHAR}, #{dataKey,jdbcType=INTEGER}, 
          #{dataValue,jdbcType=INTEGER}, #{createName,jdbcType=INTEGER}, #{createTime,jdbcType=TIMESTAMP}, 
          #{updateName,jdbcType=INTEGER}, #{updateTime,jdbcType=TIMESTAMP})
      </insert>
      
      <insert id="insertSelective" parameterType="com.shitou.huishi.domain.entity.BusinessMarketAffiliate">
        <selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
          SELECT LAST_INSERT_ID()
        </selectKey>
        insert into tb_business_market_affiliate
        <trim prefix="(" suffix=")" suffixOverrides=",">
          <if test="busiId != null">
            busi_id,
          </if>
          <if test="dataType != null">
            data_type,
          </if>
          <if test="dataKey != null">
            data_key,
          </if>
          <if test="dataValue != null">
            data_value,
          </if>
          <if test="createName != null">
            create_name,
          </if>
          <if test="createTime != null">
            create_time,
          </if>
          <if test="updateName != null">
            update_name,
          </if>
          <if test="updateTime != null">
            update_time,
          </if>
        </trim>
        <trim prefix="values (" suffix=")" suffixOverrides=",">
          <if test="busiId != null">
            #{busiId,jdbcType=INTEGER},
          </if>
          <if test="dataType != null">
            #{dataType,jdbcType=VARCHAR},
          </if>
          <if test="dataKey != null">
            #{dataKey,jdbcType=INTEGER},
          </if>
          <if test="dataValue != null">
            #{dataValue,jdbcType=INTEGER},
          </if>
          <if test="createName != null">
            #{createName,jdbcType=INTEGER},
          </if>
          <if test="createTime != null">
            #{createTime,jdbcType=TIMESTAMP},
          </if>
          <if test="updateName != null">
            #{updateName,jdbcType=INTEGER},
          </if>
          <if test="updateTime != null">
            #{updateTime,jdbcType=TIMESTAMP},
          </if>
        </trim>
      </insert>
      
      <update id="updateByPrimaryKeySelective" parameterType="com.shitou.huishi.domain.entity.BusinessMarketAffiliate">
        update tb_business_market_affiliate
        <set>
          <if test="busiId != null">
            busi_id = #{busiId,jdbcType=INTEGER},
          </if>
          <if test="dataType != null">
            data_type = #{dataType,jdbcType=VARCHAR},
          </if>
          <if test="dataKey != null">
            data_key = #{dataKey,jdbcType=INTEGER},
          </if>
          <if test="dataValue != null">
            data_value = #{dataValue,jdbcType=INTEGER},
          </if>
          <if test="createName != null">
            create_name = #{createName,jdbcType=INTEGER},
          </if>
          <if test="createTime != null">
            create_time = #{createTime,jdbcType=TIMESTAMP},
          </if>
          <if test="updateName != null">
            update_name = #{updateName,jdbcType=INTEGER},
          </if>
          <if test="updateTime != null">
            update_time = #{updateTime,jdbcType=TIMESTAMP},
          </if>
        </set>
        where id = #{id,jdbcType=INTEGER}
      </update>
      
      <update id="updateByPrimaryKey" parameterType="com.shitou.huishi.domain.entity.BusinessMarketAffiliate">
        update tb_business_market_affiliate
        set busi_id = #{busiId,jdbcType=INTEGER},
          data_type = #{dataType,jdbcType=VARCHAR},
          data_key = #{dataKey,jdbcType=INTEGER},
          data_value = #{dataValue,jdbcType=INTEGER},
          create_name = #{createName,jdbcType=INTEGER},
          create_time = #{createTime,jdbcType=TIMESTAMP},
          update_name = #{updateName,jdbcType=INTEGER},
          update_time = #{updateTime,jdbcType=TIMESTAMP}
        where id = #{id,jdbcType=INTEGER}
      </update>
    </mapper>
    View Code

    https://blog.csdn.net/u010448530/article/details/52023256

    https://www.2cto.com/database/201505/401604.html

    https://blog.csdn.net/qq_35261296/article/details/73559247

    https://blog.csdn.net/crystalssj/article/details/76549024

    https://www.kunzhao.org/blog/2017/07/23/mybatis/

  • 相关阅读:
    win10开机时内存使用率达到99%以上
    https的基本原理,看完你的程序员女朋友再也不和你提分手了
    Tomcat样例安全漏洞
    Linux5355端口被0.0.0.0监听
    jQuery的ajax
    事件委托(事件代理)
    jQuery的事件绑定和解绑
    事件对象
    JS的事件流的概念(重点)
    jQuery的位置信息
  • 原文地址:https://www.cnblogs.com/hongdada/p/9049679.html
Copyright © 2020-2023  润新知