oracle 存储过程写成mybatis xml写法
时间: 2023-11-09 21:09:12 浏览: 87
oracl存储过程以及mybatis的调用
假设有一个Oracle存储过程如下:
```
CREATE OR REPLACE PROCEDURE GET_EMPLOYEES_BY_DEPT(
DEPT_ID IN NUMBER,
EMPLOYEES OUT SYS_REFCURSOR
) AS
BEGIN
OPEN EMPLOYEES FOR
SELECT * FROM EMPLOYEES WHERE DEPT_ID = DEPT_ID;
END;
```
可以通过以下方式将其转换为MyBatis的XML写法:
```
<select id="getEmployeesByDept" statementType="CALLABLE" resultType="Employee">
{call GET_EMPLOYEES_BY_DEPT(
#{deptId, mode=IN, jdbcType=INTEGER},
#{employees, mode=OUT, jdbcType=CURSOR, javaType=ResultSet, resultMap=employeeResultMap}
)}
</select>
```
需要注意的几点:
- `statementType="CALLABLE"` 表示这是一个存储过程调用语句。
- `resultType="Employee"` 表示查询结果会映射为 `Employee` 对象。
- `#{deptId, mode=IN, jdbcType=INTEGER}` 表示传入参数 `DEPT_ID`,类型为 `INTEGER`。
- `#{employees, mode=OUT, jdbcType=CURSOR, javaType=ResultSet, resultMap=employeeResultMap}` 表示输出参数 `EMPLOYEES`,类型为 `CURSOR`,Java类型为 `ResultSet`,并使用 `employeeResultMap` 进行结果映射。需要提前定义 `employeeResultMap`。
- `{call ...}` 中的 `...` 是存储过程调用语句,参数使用 `#{}` 占位符进行传递。注意其中的 `DEPT_ID = DEPT_ID`,这是因为存储过程中的参数名与传入的参数名相同,需要通过重复使用参数名来避免名称冲突。
阅读全文