最近安裝了datagrip操作達夢資料庫,發現有一個問題:dagagrip無法獲取dbms_output的輸出,在oracle是可以的,但在達夢不行。 於是聯想到一個問題:c語言裡面怎麼獲取dbms_output的輸出? 百度了一下,沒有找到明確的答案,但是找到了jdbc獲取dbms_output輸 ...
最近安裝了datagrip操作達夢資料庫,發現有一個問題:dagagrip無法獲取dbms_output的輸出,在oracle是可以的,但在達夢不行。
於是聯想到一個問題:c語言裡面怎麼獲取dbms_output的輸出?
百度了一下,沒有找到明確的答案,但是找到了jdbc獲取dbms_output輸出的方法: 鏈接見這裡 https://blog.csdn.net/jswxharry/article/details/7861666
大概原理是使用dbms_output.getline函數獲取dbms_output的輸出,並保存到存儲過程出參。使用jdbc獲取對應參數的值即可。
getline的示例用法:
declare
line varchar2(100);
status number;
begin
dbms_output.enable;
dbms_output.put_line('偉大的中華民族');
dbms_output.put('中國');
dbms_output.put(',偉大的祖國');
dbms_output.get_line(:line,:status); -- get_line返回後如果status為1代表失敗
dbms_output.put_line('put_line ' || :status);
dbms_output.put_line('put_line ' || :line);
end;
輸出:
put_line 0
put_line 偉大的中華民族
c語言要獲取dbms_output的輸出,想來也可以使用類似的方法。不過這個方法使用起來稍有點麻煩,我想出了一個優化方法:
c語言獲取某個sql的返回結果是比較方便的,我只要把dbms_output的輸出轉換到一張表裡面,再對該表做查詢即可。
為此,我建了一張表tb_dbms_output,用於存放dbms_output的輸出,並且寫了一個簡單的存儲過程,作用是獲取dbms_output的輸出,把它們登記到tb_dbms_output
詳細代碼如下:
Create Global Temporary Table tb_dbms_output -- 皇家救星:tb_dbms_output 是一張事務級別的臨時表,只要一提交事務,就會自動清空。
(
line number,
output_text varchar2(4000)
) On Commit Delete Rows;
create index idx_tb_dbms_output_line on tb_dbms_output(line);
select * from tb_dbms_output;
-- 需要同時選擇11~28行運行,分開運行不能獲取結果
begin dbms_output.put_line('1334'); end;
/
declare
status number := 0;
output_text varchar2(4000);
line number := 1;
begin
loop
status := 0;
dbms_output.get_line(output_text, status);
exit when status = 1;
insert into tb_dbms_output values(line, output_text);
line := line + 1;
end loop;
end;
/
select * from tb_dbms_output order by 1; -- kingstarer:
commit;
以上代碼在plsql developer和達夢資料庫管理工具測試,均可得到預期結果。
希望這篇文章對你有幫助。