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

来源:https://www.cnblogs.com/kingstarer/archive/2020/06/14/13122643.html
-Advertisement-
Play Games

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

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • docker-compose項目是docker官方的開源項目,負責實現對docker容器集群的快速編排;所謂編排我們可以理解為像ansible裡面的"劇本";我們把需要啟動的容器,每個容器之間的依賴關係,每個容器的網路、存儲等等都定義在一個配置文件中,然後通過一個工具去讀取這個配置文件,從而實現快... ...
  • 大家一定有看過好萊塢電影,電影里的一幕大家一定印象深刻:男主角在電腦前熟練地敲著鍵盤,電腦屏幕飛快地閃動,字元也在快速跳動,很有科技感! 這樣的效果,在 Linux 下也可以實現,甚至連不懂任何 IT 技術的小白跟著本教程也可以輕鬆裝13。 我們先來看看 Linux 下的效果,看看跟電影是否類似。 ...
  • 本篇文章主要闡述了VirtualBox的使用,Linux的分區,CentOS7操作系統的安裝與IP配置,MobaXterm遠程工具的使用 ...
  • linux 用戶 1、用戶相關 1.1useradd useradd 選項 用戶名 1.2passwd passwd 選項 用戶名 1.3 例子: 1.3.1創建用戶testuser 主目錄為home/testuser useradd –d /home/testuser -m testuser 1. ...
  • 最近開始接觸websocket,第一次裝的時候,還是遇到了些問題,這裡記錄一下 1.從git下載uWebSockets 地址:https://github.com/uNetworking/uWebSockets git clone https://github.com/uNetworking/uWe ...
  • Linux基礎知識、Shell編程、Linux系統管理、Linux服務管理、MySQL資料庫管理、Linux集群、Linux虛擬化 ...
  • 本文主要闡述了UNIX與Linux發展史、開源軟體簡介、Linux應用領域 ...
  • 單行編輯控制項具有ES_密碼樣式。預設情況下,具有此樣式的編輯控制項為用戶鍵入的每個字元顯示一個星號。 但是,本例使用EM_SETPASSWORDCHAR消息將預設字元從星號更改為加號(+)。以下屏幕截圖顯示用戶輸入密碼後的對話框。 步驟1:創建密碼對話框的實例。 下麵的C++代碼示例使用DealBox ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...