MyBatis调用java函数

本文介绍了如何在MyBatis中使用Java静态函数来动态处理SQL语句,通过TestMapper接口和mapper.xml配置文件展示了插入操作的例子,并强调了调用静态函数的注意事项,包括函数必须为静态、SQL字符串避免使用双引号等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MyBatis调用Java静态函数

mappper.java

@Mapper
@Repository
public interface TestMapper {

    void insert(Map params);

    void insert2(@Param("file") String file,@Param("date") Date date);

mapper.xml

<?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.xxx.mapper.TestMapper">


    <!--INSERT INTO dbo.Test([File],[Time]) VALUES('File2', '2021-07-05 15:55:12.123')-->
    <insert id="insert" parameterType="map">
        INSERT INTO dbo.Test([File],[Time]) VALUES(#{file}, #{date})
    </insert>

    <insert id="insert2">
        INSERT INTO dbo.Test([File],[Time]) VALUES(#{file}, &apos;${@com.scanning.utils.ConvertUtils@convertTime(date)}&apos;)
    </insert>

</mapper>

调用的java函数

 public static String convertTime(Date date){
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");

        return simpleDateFormat.format(date);
    }

测试函数

    @Test
    public void insert3Test(){

        mapper.insert2("12122",new Date());
    }

注意事项

java函数必须是静态函数
MyBatis sql语句中字符串不能使用双引号

xml常用转义字符

附:XML转义字符 
&lt;                    <       小于号                                            
&gt;                   >       大于号 
&amp;                &       和 
&apos;               '        单引号 
&quot;               "        双引号 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值