mybatis

6 篇文章 0 订阅
3 篇文章 0 订阅

1.MyBatis的传参相关问题

1.1.在dao层写了如下接口

int deleteKAInDataBySysNo(@Param("sysNo") String sysNo);

并在xml文件中做了如下配置

<delete id="deleteKAInDataBySysNo" parameterType="java.lang.String" >
	delete from ka_in where ${_parameter}
</delete>

这里面有两个需要注意的点
(1)当传入的参数为字符串时,要使用“$”来进行链接,
举个例子,如果传入的参数值为字符串 “id=1”,使用那么使用上面的符号进行连接时,sql语句就变成了delete from ka_in where id=1
如果使用“#”来取值sql语句就会变成delete from ka_in where “id=1”,这样就会报错,因为执行的时候会把后面那个当作字符串而非sql语句的一部分
(2)当传入的参数不是用对象封装(包括数组),也就是说传入的值只有value没有key,这个时候取参数的时候就需要使用“{_parameter}”这样的方式来取值,以上面那个例子来说,不能使用{sysNo}这样的方式来取值
(3)如果传入的参数为对象类型,取值的时候直接“#{对象的属性名}”就直接可以取到值了

1.2.类型转换问题

1.2.1.mybatis将0自动转化成了null

原因:

<if test="companyState != null and companyState != ''">
    and company_state = #{companyState,jdbcType=TINYINT}
</if>

companyState该字段时Short类型的,但是条件判断(test)中,使用了

test="companyState != null and companyState != ''"

判断了该字段不为null,也不为空串;如果该字段的值不为0时,这样判断没有任何问题;但是,如果当该字段的值为0时,使用这样的判断方式,会导致mybatis将0转化成null,那么这条判断语句就失去了意义;
解决办法:
将上面的判断修改成下面这样,去掉不为空串的判断

test="companyState != null"

总结:

如果字段类型为String这么判断没有任何问题,如果是数字类型,一定要注意!不能这么写!

1.2.2.数据库字段类型与代码中传入的类型不一致

问题背景:数据库中的字段为varhcar,代码中为Long,需要将代码中的入参Long类型,修改为string类型

解决办法:

使用MyBatis提供的TypeHandler进行入参、出参的数据类型转换

步骤

1.实现TypeHandler接口
@MappedTypes(value = Long.class)
@MappedJdbcTypes(value = JdbcType.VARCHAR)
public class StringHandler implements TypeHandler<Long> {
    public void setParameter(PreparedStatement preparedStatement, int i, Long parameter, JdbcType jdbcType) throws SQLException {
        String paramString = String.valueOf(parameter);
        preparedStatement.setString(i,paramString);
    }
    public Long getResult(ResultSet resultSet, String s) throws SQLException {
        return Long.valueOf(resultSet.getString(s));
    }
    public Long getResult(ResultSet resultSet, int i) throws SQLException {
        return Long.valueOf(resultSet.getString(i));
    }
    public Long getResult(CallableStatement callableStatement, int i) throws SQLException {
        return Long.valueOf(callableStatement.getString(i));
    }
}
分两种情况:
1.1.如果对全局都使用,则在配置文件中my-mybatis-config.xml配置即可,mapper.xml中不需要做任何修改,所有mapper.xml使用到(入参是Long的都会被转换成varchar)
<configuration>
	<typeHandlers>
        <typeHandler jdbcType="VARCHAR" javaType="java.lang.Long" handler="com.my.test.handler.StringHandler"/>
    </typeHandlers>
</configuration>
注意:也可以在springboot的application.yml中进行配置,跟配置文件是一样的效果:
mybatis:
	type-handlers-package: com.git.hui.boot.mybatis.handler

1.2.只针对某个sql使用,则在mybatis的xml文件中修改出参,入参
出参:
<result property="myId" column="my_id" typeHandler="com.my.test.handler.StringHandler"/>
where条件中的入参:
<if test="*****">
	AND my_id =#{myId,typeHandler=com.my.test.handler.StringHandler}
</if>

2.MyBatis中sql相关问题

当设置了表的主键为自增时,可以再mapper.xml文件中使用下面的参数,来获取数据插入之后自增的主键id;插入之后的自增主键id,会被封装再参数对象中,例如下面的主键id,就会封装在里面,该插入语句不用返回值,直接可以获取到testLog中插入生成的主键id

mytest.insert(testLog);
<insert id="save" parameterType="com.my.test"
useGeneratedKeys="true" keyProperty="id">
        insert into ...
</insert>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值