国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

關于Oracle和SQL存儲調試和出錯處理

瀏覽:2日期:2023-11-13 18:04:03
在大型數據庫中,因為開發的需要,經常需要調用Procedure。在Oracle和SQLServer上開發Procedure因為語法不同,而有所區別;調試Procedure,在兩個系統上都不太輕易,尤其是進行錯誤處理時更是如此。 調試: 1. 對于Oracle的調試,可以借助于第三方的工具,比如Pl/SQL Developer,以6.0.5.926版本為例,首先對該Procedure右鍵處理,添加“add debug information”,然后選擇“test”,打開新的測試窗口,在下方對應的輸入輸出變量處,添加相應的測試數據。注重:這里的數據輸入,不需要引號,輸出參數不需要輸入! 然后點擊“start debugger”,或者按F9進行測試,可以選擇測試的步驟如“step into”等,然后可以在下面的script窗口看到中間變量。 2. 對于SQLServer調試,在沒有找到較好的第三方工具的情況下,目前采用的是將中間的變量值或者SQL語句插入到另一個表中,或者直接print出來的方式。第一種需要借助 exec('') 方法,注重里面的取變量值的寫法,可參考下面的例子: exec('update SupplyplanLack set Completedate = GetDate()from supplyPlanLack a where '+ @ssTmp +' and'+@iCompleteQty+' >= (select s.RequestQty * a.RationQty as ReQQtyfrom Balance a, SupplyPlan s where a.Vehicle = s.Vehicleand a.Part=s.Part and a.SupplyPlanNo = s.SupplyPlanNoand '+ @ssTmp +')')在print中,需要注重類型的轉換,一般是借用 convert(varchar(11),@spNOTo) 方法來實現,否則會提示類型轉換錯誤。 3. 錯誤處理上,對于SQLServer可以采用開始自定義變量,然后根據不同判定,改變該值再推出的方法來處理,見下例: set @exec_num=0if (@spNOFrom=0 or @spNOTo=0 or @reuseUser=NULL)beginset @exec_num=1goto the_endendthe_end:return或者是這種: set nocount onif (@property is null) or (@property = '')beginraiserror('Must specify a property name.',-1,-1)return (1)end或者是對該錯誤全局變量 @@error 數值的判定上。
標簽: Oracle 數據庫
主站蜘蛛池模板: 涟源市| 南漳县| 迭部县| 休宁县| 四子王旗| 宜春市| 秦安县| 固始县| 饶河县| 临泉县| 赤水市| 班玛县| 林州市| 栖霞市| 溧阳市| 河北区| 金阳县| 准格尔旗| 新蔡县| 凤庆县| 宣恩县| 尉犁县| 山丹县| 巴彦县| 宁德市| 云南省| 广东省| 通山县| 南平市| 乐安县| 四平市| 沙雅县| 若尔盖县| 东阳市| 墨玉县| 新沂市| 临夏市| 平和县| 雷山县| 股票| 洪江市|