Mybatis-Plus调用PG Sql存储过程

本文详细介绍了如何使用Mybatis-Plus调用PostgreSQL存储过程的两种方法,包括使用@Select注解和call关键字。针对不同场景,如只传递常规参数和包含数组参数的情况,提供了具体的实现步骤和注意事项,包括自定义类型转换器的实现。
摘要由CSDN通过智能技术生成

使用Mybatis-Plus调用pgsql存储过程两种方法

1.使用@Select注解

使用方法:在dao层接口上加@Select注解,括号写 select +调存储过程名。
语法:

select 存储过程名( #{column1}, #{column2} …)

注意:
1.有入参时,@Selec注解中的参数名要和接口@Param注解里的参数名一致。
2.如果要调的存储过程没有入参就不用传参数

例:

    @Select("select funName(#{column1},#{column2}...)")
    Object funName(@Param("column1") String column1,@Param("column2") Integer column2...);

注意:
1).@Select注解里的参数顺序和接口里的参数顺序要保持一致。
2).使用@Select注解的方式有局限性,当需要给存储过程传入数组时,使用注解的方式会报错,原因是mybatis默认提供的类型转换器会失效,这时需要自定义一个类型转换器,并使用call关键字调用存储过程,call方法支持传递数组

2.使用call关键字

使用场景1:只传递常规参数(如:Integer,String,Double…)

1.定义dao层接口,就像你平时做的一样,只不过参数需要放入map中

    void funName(Map<String,Object> paramsMap);

2.编写mapper,其中“mode=IN”语句是固定的,表示参数是输入参数。

	<select id="funName" parameterType="java.util.HashMap" statementType="CALLABLE">
        { call funName(#{column1,mode=IN},#{column2,mode=IN}...) }
    </select >

使用场景2:入参中有数组

使用call关键字调用存储过程并传递数组时,需要先自定义一个类作为类型处理器,实现 org.apache.ibatis.type.TypeHandler 接口, 或继承org.apache.ibatis.type.BaseTypeHandler, 再将该类指定到call中,就可以将数组映射到一个 JDBC 类型。

1.自定义ArrayTypeHandler类型处理器,继承TypeHandler接口:

代码:

import org.apache.ibatis.type.BaseType
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
使用Mybatis-Plus调用存储过程需要先定义一个Mapper接口,然后在接口中定义一个方法,方法名和存储过程名一致,使用@Select注解标注该方法,同时在@Select注解中指定存储过程的名称和参数类型。 例如,假设有一个存储过程名为"get_user_by_id",接收一个int类型的参数,返回一个User对象,那么可以定义一个Mapper接口如下: ``` public interface UserMapper extends BaseMapper<User> { @Select("call get_user_by_id(#{id, mode=IN, jdbcType=INTEGER}, #{result, mode=OUT, jdbcType=CURSOR, resultMap=userResultMap})") void getUserById(@Param("id") int id, @Param("result") ResultSet[] result); } ``` 在@Select注解中,使用"call"关键字指定调用存储过程,然后使用"#{参数名, mode=IN, jdbcType=参数类型}"指定输入参数,"#{参数名, mode=OUT, jdbcType=参数类型, resultMap=结果集映射}"指定输出参数,其中"resultMap"指定输出结果集的映射关系。 调用该方法时,可以使用Mybatis-Plus提供的SqlSessionTemplate执行调用: ``` @Autowired private SqlSessionTemplate sqlSessionTemplate; public User getUserById(int id) { UserMapper mapper = sqlSessionTemplate.getMapper(UserMapper.class); ResultSet[] result = new ResultSet[1]; mapper.getUserById(id, result); User user = null; try { if (result[].next()) { user = new User(); user.setId(result[].getInt("id")); user.setName(result[].getString("name")); user.setAge(result[].getInt("age")); } } catch (SQLException e) { e.printStackTrace(); } return user; } ``` 在调用getUserById方法时,先获取UserMapper的实例,然后创建一个ResultSet数组作为输出参数,调用getUserById方法,最后从输出参数中获取结果集并转换为User对象返回。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值