Mybatis 执行任意 SQL 字符串

Mybatis 执行任意 SQL 字符串

直接上代码:

import org.apache.ibatis.annotations.Select;
import org.springframework.stereotype.Repository;

import java.util.List;
import java.util.Map;

/**
 * @Author: Jimmy
 * @Date: 2022-02-15 11:35
 * @Description: mybatis执行sql字符串
 */
@Repository
public interface SqlMapper {

    /**
     * mybatis执行sql字符串
     *
     * @param sql
     * @return
     */
    @Select({"${sql}"})
    List<Map<String, Object>> executeSql(String sql);
}

调用:

import com.sinochem.api.mapper.SqlMapper;
import lombok.extern.slf4j.Slf4j;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import java.util.List;
import java.util.Map;

/**
 * @Author: Jimmy
 * @Date: 2021-08-27 17:25
 * @Description: 测试类
 */

@Slf4j
@RunWith(SpringRunner.class)
@SpringBootTest
@AutoConfigureMockMvc
public class Test {
    @Autowired
    private SqlMapper sqlMapper;

    @org.junit.Test
    public void test1() {

        List<Map<String, Object>> maps = sqlMapper.executeSql("select * from auth_config where delete_flag = 0");
        System.out.println(maps);
    }

}

测试结果:
在这里插入图片描述

存在注入风险,谨慎使用!!!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值