반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- TensorFlow
- webpack
- react
- unittest
- Chrome
- 개발
- 센토스
- Android
- vsCode
- VirtualBox
- 리눅스
- localserver
- qunit
- 티스토리챌린지
- jest
- centos
- ReactNative
- xcode
- PYTHON
- MAC
- 오블완
- MachineLearning
- node
- 네트워크
- 맥
- IOS
- androidstudio
- linux
- build
Archives
- Today
- Total
로메오의 블로그
[Spring Boot] myBatis Procedure / function 호출 본문
반응형
Spring Boot / Oracle / Mybatis 차례
<mapper namespace="com.gaeyou.project.store.mapper.ProjectMapper">
<!-- 프로시저 호출하기 -->
<insert id="saveData" parameterType="com.gaeyou.project.entity.ProjectDTO" statementType="CALLABLE">
{ CALL /* saveData */
SP_SAVE_DATA (
IN_OPERATION => #{operation , mode=IN , jdbcType=VARCHAR}
,IN_DATA => #{data , mode=IN , jdbcType=VARCHAR}
,RETURN_CODE => #{returnCode , mode=OUT , jdbcType=VARCHAR}
,ERROR_MSG => #{errorMsg , mode=OUT , jdbcType=VARCHAR}
)
}
</insert>
<!-- 함수 호출하기 -->
<select id="retrieveData" parameterType="com.gaeyou.project.entity.ProjectDTO" resultType="com.gaeyou.project.entity.ProjectDTO">
<![CDATA[
SELECT /* retrieveData */
FN_RETRIEVE_DATA(
#{data, jdbcType="VARCHAR"}
,#{name, jdbcType="VARCHAR"}
,#{age, jdbcType="NUMERIC"}
) AS RESULT_VALUE
FROM DUAL
]]>
</select>
</mapper>
CREATE OR REPLACE PROCEDURE SP_SAVE_DATA (
IN_OPERATION IN VARCHAR2 --
, IN_DATA IN VARCHAR2 --
, RETURN_CODE IN OUT VARCHAR2 --
, ERROR_MSG IN OUT VARCHAR2 --
) IS
BEGIN
RETURN_CODE := 0
ERROR_MSG := '';
IF TRIM(IN_OPERATION) IS NULL THEN
RETURN_CODE := -1;
ERROR_MSG := 'NO SELECTED INFO';
RETURN
END IF;
IF IN_OPERATION = 'C' THEN
INSERT INTO TABLE(
DATA
)
SELECT
IN_DATA
FROM DUAL;
ELSEIF IN_OPERATION = 'U' THEN
UPDATE TABLE SET
DATA = IN_DATA;
ELSEIF IN_OPERATION = 'D' THEN
DELETE FROM TABLE;
END IF;
EXCEPTION WHEN OTHER THEN
RETURN_CODE := -1;
ERROR_MSG := 'EXCEPTION ERROR'
END;
CREATE OR REPLACE FUNCTION FN_RETRIEVE_DATA (
IN_DATA IN VARCHAR2
,IN_NAME IN VARCHAR2
,IN_AGE IN NUMBER
) RETURN NUMBER
PRAGMA AUTONOMOUS_TRANSACTION;
RETURN_VAL NUMBER;
BEGIN
IF IN_DATA IS NULL OR IN_NAME IS NULL THEN
RETURN -1;
END IF;
BEGIN
SELECT
1 AS RETURN_VAL
FROM DUAL
END
COMMIT
RETURN RETURN_VAL
EXEPTION WHEN OTHERS THEN
RETURN -1;
END;
반응형
'Backend > Spring' 카테고리의 다른 글
[Spring] IN 조건문을 위한 foreach 사용하기 - myBatis, sql (0) | 2019.12.20 |
---|---|
[Spring Boot] 파일 업로드 처리 - ajax file upload (0) | 2019.12.11 |
[Spring boot] 예외처리 - GlobalExceptionHandler - ControllerAdvice (0) | 2019.10.15 |
[Spring boot] HttpSession 세션 처리 - Interceptor (0) | 2019.10.15 |
[Spring boot] mybatis SQL 로그 찍기 - log4jdbc (0) | 2019.10.12 |
Comments