C語言獲取dbms_output輸出的方法(適用於oracle和達夢)


最近安裝了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和達夢數據庫管理工具測試,均可得到預期結果。

希望這篇文章對你有幫助。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM