spring+springMvc+mybatis 调用oracle 存储过程
最近在項(xiàng)目中遇到在mybatis中調(diào)用oracle存儲過程的問題,網(wǎng)上各種查詢,最終解決了問題,在我們項(xiàng)目中我只需要oracle 的存儲過程返回一個字符串用來存入數(shù)據(jù)庫作為表數(shù)據(jù)的主鍵,
接下來整理代碼:
?首先構(gòu)建存儲過程getSequence,一個輸入,輸出參數(shù)。
省略數(shù)據(jù)庫表的創(chuàng)建。
?create or replace?
procedure getSequence(tableName in varchar2, outId out varchar2)
is
PRAGMA AUTONOMOUS_TRANSACTION; --自治事務(wù)?
ls_year varchar2(4); --年度
ls_month varchar2(2); --月度
ls_day varchar2(2); --日
--自治事務(wù): 防止外層事務(wù)調(diào)用內(nèi)層事務(wù)時被內(nèi)層事務(wù)中的commit提交了不該提交的內(nèi)容?
--version: 2.0
begin
ld_date := sysdate;
ls_table := lower(as_table_code);
ls_year := To_char(ld_date, 'yyyy' );
ls_month := To_char(ld_date, 'mm' );
ls_day := To_char(ld_date, 'dd' );
select nvl(max(sequence_value),0)
into ld_value
from sm_sequence
where sequence_code = ls_table ;
If ld_value = 0 then
ld_value := 1;
insert into sm_sequence
(sequence_code,
sequence_year,
sequence_month,
sequence_day,
sequence_value )
values
(ls_table,
to_char( sysdate, 'yyyy' ),
to_char( sysdate, 'mm' ),
to_char( sysdate, 'dd' ),
ld_value );
else
select sequence_year, sequence_month, sequence_day, sequence_value
into ln_year, ln_month, ln_day, ld_value
from sm_sequence
where sequence_code = ls_table;
if ln_year <> to_number(to_char(sysdate, 'yyyy')) or
ln_month <> to_number(to_char(sysdate, 'mm')) or
ln_day <> to_number(to_char(sysdate, 'dd')) then
ld_value := 1;
else
ld_value := ld_value + 1;
end if;
update sm_sequence
set sequence_value = ld_value,
sequence_year = ls_year,
sequence_month = ls_month,
sequence_day = ls_day
where sequence_code = ls_table ;
End If;
commit;
as_id := ls_year ||ls_month||ls_day||ltrim(to_char(ld_value, '00000000' ));
end ;
函數(shù)構(gòu)建完成;
在pl/sql 中調(diào)用:
?
SQL> set serveroutput onSQL> DECLARE
2 tableName varchar2(20);
3 row_id varchar2(10);
4 BEGIN
5 getSequence(tableName,row_id);
6
7 dbms_output.put_line(row_id); 8 END;
9 /
ename
?
?
在Spring+springMVC+myBatis項(xiàng)目中調(diào)用,
java調(diào)用:
dao層:
public interface?getMapper(){
public void getSequence(HashMap<String,Object> params);
}
mybatis 層xml 配置:
<parameterMap type="java.util.Map" id="getUserCountMap">
<parameter property="tableName" mode="IN" jdbcType="VARCHAR"/>
<parameter property="rowId" mode="OUT" jdbcType="VARCHAR"/>
</parameterMap>
<select id="getSequence" statementType="CALLABLE"
parameterMap="getUserCountMap" >
{call getSequence?(?,?)}
</select>
service層調(diào)用:
HashMap<String,Object> param =new HashMap<String,Map>();
param.put("tableName","表名");
getMapper.getSequence(param);//此處特別注意調(diào)用時不需要返回類型,一旦執(zhí)行完存儲過程map中就已經(jīng)存在值
System.out.print(param.get("rowId"));
以上是這次項(xiàng)目開發(fā)中遇到的問題,另外spring+springMVC+mybatis調(diào)用oracle存儲過程返回多條數(shù)據(jù)的還在研究中,先整理這么多
?
轉(zhuǎn)載于:https://www.cnblogs.com/zhencode666/p/6063536.html
總結(jié)
以上是生活随笔為你收集整理的spring+springMvc+mybatis 调用oracle 存储过程的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 一步步学习SPD2010--第二章节--
- 下一篇: 网易云音乐产品体验报告