亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 如何將sql執行的錯誤消息記錄到本地文件中實現過程

如何將sql執行的錯誤消息記錄到本地文件中實現過程

熱門標簽:美團地圖標注商戶認證注冊 榕城市地圖標注 怎么給高德做地圖標注 承德地圖標注公司名需要花錢嗎 浙江穩定外呼系統供應商 咸陽電腦外呼系統運營商 北京400電話辦理多少錢 慶陽地圖標注 電銷外呼系統軟件功能

其實大家都知道sql語句的錯誤信息都可以在sys.messages表里面找到

如:

如果在執行語句在try...catch中 我們可以通過以下方法獲取錯誤信息。sql語句如下:

復制代碼 代碼如下:

BEGIN TRY
SELECT 3 / 0
END TRY
BEGIN CATCH
DECLARE @errornumber INT
DECLARE @errorseverity INT
DECLARE @errorstate INT
DECLARE @errormessage NVARCHAR(4000)
SELECT @errornumber = ERROR_NUMBER() ,
@errorseverity = ERROR_SEVERITY() ,
@errorstate = ERROR_STATE() ,
@errormessage = ERROR_MESSAGE()

SELECT @errornumber ,
@errorseverity ,
@errorstate ,
@errormessage

RAISERROR (
@errormessage, -- Message text,
@errorseverity, -- Severity,
@errorstate, -- State,
@errornumber
);
END CATCH

當然我這里是故意用RAISERROR再次拋出錯誤信息,運行結果如下:

現在我們來定義一個存儲過程,其目的就是往本地文件中寫入信息。

sql腳本如下:

復制代碼 代碼如下:

CREATE Proc [dbo].[UCreateOrAppendTextFile](@Filename VarChar(100),@Text nVarchar(4000))
AS
DECLARE @FileSystem int
DECLARE @FileHandle int
DECLARE @RetCode int
DECLARE @RetVal int
DECLARE @CreateOrAppend int

EXECUTE @RetCode = sp_OACreate 'Scripting.FileSystemObject' , @FileSystem OUTPUT
IF (@@ERROR|@RetCode > 0 Or @FileSystem 0)
RAISERROR ('could not create FileSystemObject',16,1)
EXECUTE @RetCode = sp_OAMethod @FileSystem , 'FileExists', @RetVal out, @FileName
IF (@@ERROR|@RetCode > 0)
RAISERROR ('could not check file existence',16,1)
-- If file exists then append else create
SET @CreateOrAppend = case @RetVal when 1 then 8 else 2 end
EXECUTE @RetCode = sp_OAMethod @FileSystem , 'OpenTextFile' , @FileHandle OUTPUT , @Filename, @CreateOrAppend, 1
IF (@@ERROR|@RetCode > 0 Or @FileHandle 0)
RAISERROR ('could not create File',16,1)
EXECUTE @RetCode = sp_OAMethod @FileHandle , 'WriteLine' , NULL , @text
IF (@@ERROR|@RetCode > 0 )
RAISERROR ('could not write to File',16,1)
EXECUTE @RetCode = sp_OAMethod @FileHandle , 'Close'
IF (@@ERROR|@RetCode > 0)
RAISERROR ('Could not close file ',16,1)
EXEC sp_OADestroy @filehandle
IF (@@ERROR|@RetCode > 0)
RAISERROR ('Could not destroy file object',16,1)
EXEC sp_OADestroy @FileSystem

----------------------------------------
然后執行該存儲過程:
復制代碼 代碼如下:

exec UCreateOrAppendTextFile 'C:\Error.log','hello majaing'

如果遇到以下錯誤則說明Ole Automation Procedures沒有啟用

需要執行以下SQL:

復制代碼 代碼如下:

go
sp_configure 'show advanced options', 1;
GO
RECONFIGURE;
GO
sp_configure 'Ole Automation Procedures', 1;
GO
RECONFIGURE;
GO

運行即如果如圖:

當然這里運行存儲過程之前必須保證 文件是存在的。

最后封裝一個存儲過程獲取錯誤信息,其腳本如下:

復制代碼 代碼如下:

CREATE PROCEDURE LOGError(@msg nvarchar(400))
as
declare @text nvarchar(400)
SELECT @text=text FROM sys.messages WHERE language_id=1033 AND message_id=@@ERROR
if len(@text)>1
begin
set @msg=@msg +' : '+@text
EXEC dbo.UCreateOrAppendTextFile 'C:\Error.log',@msg
end

執行存儲過程及結果如下:

以上存儲過程在MSSQL2005、2012中測試通過。

大家都知道目前在文件系統中事務的實現還是比較復雜的,雖然在win7后我們可以用C#實現文件的事務,但是微軟的分布式事務Distributed Transaction Coordinator(msdtc)目前也還不支持文件事務。

這里說說為什么有這樣的需求吧:目前需要一個項目用SSIS做數據遷移,其中很大部分都是用sql語句實現的, 如 insert into ....select ... from xxxx.其中原數據庫中難免有什么臟數據導致插入失敗,于是我在SSIS中使用msdtc服務,保證數據的一致性。雖然SSIS也有錯誤處理,但是它只能記錄那個sql語句有問題,而不能記錄具體問題。于是我想到把錯誤信心記錄報數據庫表里面,可是當遇到問題時事務會回滾,表里面根本就沒有錯誤信息。于是乎 只能報錯誤信息記錄到文件中了。

如:

有不對的地方還請大家拍磚哦!

標簽:重慶 呼和浩特 昭通 貴州 上海 新鄉 拉薩 江蘇

巨人網絡通訊聲明:本文標題《如何將sql執行的錯誤消息記錄到本地文件中實現過程》,本文關鍵詞  如何,將,sql,執,行的,錯誤,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《如何將sql執行的錯誤消息記錄到本地文件中實現過程》相關的同類信息!
  • 本頁收集關于如何將sql執行的錯誤消息記錄到本地文件中實現過程的相關信息資訊供網民參考!
  • 推薦文章
    在线观看导航| 国产高清视频免费观看| 一a一级片| 精品视频免费在线| 亚洲爆爽| 成人免费福利片在线观看| 久久成人性色生活片| 999久久66久6只有精品| 日韩免费片| 99热精品在线| 韩国毛片免费| 午夜在线亚洲男人午在线| 国产一区二区精品| 青草国产在线| 亚洲女初尝黑人巨高清在线观看| 可以免费看污视频的网站| 精品久久久久久中文字幕一区| 精品国产一区二区三区国产馆| 天天做人人爱夜夜爽2020毛片| 999精品影视在线观看| 日韩专区一区| 午夜激情视频在线观看| 91麻豆国产福利精品| 91麻豆国产福利精品| 精品国产一区二区三区久久久狼 | 一本伊大人香蕉高清在线观看| 久久国产精品只做精品| 日本特黄特黄aaaaa大片| 麻豆网站在线看| 亚洲 国产精品 日韩| 97视频免费在线观看| 午夜激情视频在线观看| 日韩免费片| 国产网站免费视频| 亚欧成人毛片一区二区三区四区| 国产伦精品一区二区三区无广告| 精品久久久久久中文字幕2017| 国产视频一区二区在线观看| 台湾毛片| 欧美国产日韩一区二区三区| 国产精品免费久久| 二级片在线观看| 日韩专区一区| 久久久久久久男人的天堂| 国产视频网站在线观看| 国产高清视频免费观看| 色综合久久天天综线观看| 99久久精品国产免费| 美女被草网站| 黄视频网站在线免费观看| 欧美激情一区二区三区在线| 日韩女人做爰大片| 国产高清在线精品一区a| 久久成人性色生活片| 四虎影视久久| 久久成人性色生活片| 久久福利影视| 亚洲精品中文字幕久久久久久| 精品视频免费看| 色综合久久天天综合观看| 久久久成人网| 九九干| 黄视频网站在线观看| 国产不卡高清在线观看视频| 精品久久久久久中文字幕一区| 中文字幕Aⅴ资源网| 久久福利影视| 久久久久久久久综合影视网| 毛片的网站| 青青青草影院| 日韩男人天堂| 久久精品免视看国产成人2021| 国产高清视频免费观看| 欧美激情伊人| 91麻豆国产级在线| 深夜做爰性大片中文| 欧美国产日韩在线| 国产激情视频在线观看| 久久久久久久免费视频| 日韩欧美一二三区| 九九干| 国产精品免费久久| 国产不卡在线播放| 黄色免费网站在线| 91麻豆精品国产高清在线| 国产成人精品一区二区视频| 亚洲不卡一区二区三区在线| 精品视频在线看 | 久久国产影视免费精品| 国产伦理精品| 国产国语对白一级毛片| 日本特黄特黄aaaaa大片| 亚洲精品久久玖玖玖玖| 久久久久久久免费视频| 国产一区二区福利久久| 亚洲 国产精品 日韩| 韩国三级香港三级日本三级la| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 精品视频在线看 | 欧美另类videosbestsex视频 | 四虎久久精品国产| 亚洲www美色| 国产一区免费在线观看| 欧美日本韩国| 日韩专区一区| 精品视频在线观看免费| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 99久久精品国产片| 精品在线视频播放| 日本伦理网站| 台湾毛片| 黄视频网站免费看| 免费一级片在线观看| 成人高清视频在线观看| 色综合久久久久综合体桃花网| 欧美一区二区三区性| 香蕉视频久久| 九九久久国产精品| 精品国产一区二区三区国产馆| 国产伦久视频免费观看 视频| 久久精品成人一区二区三区| 精品国产一区二区三区久久久狼 | 免费毛片播放| 91麻豆爱豆果冻天美星空| 精品毛片视频| 欧美一区二区三区性| 中文字幕一区二区三区精彩视频| 精品毛片视频| 日韩专区第一页| 九九久久99| 国产视频一区二区三区四区| 台湾毛片| 成人免费一级毛片在线播放视频| 日韩中文字幕在线亚洲一区| 黄色短视屏| 精品视频在线观看免费| 国产一区二区福利久久| 天天做日日爱| 欧美激情一区二区三区视频高清| 久草免费在线视频| 精品久久久久久中文| 亚洲 欧美 91| 日韩一级精品视频在线观看| 日韩中文字幕一区二区不卡| 久久国产精品只做精品| 精品在线观看一区| 成人a大片高清在线观看| 久久国产精品只做精品| 中文字幕97| 日日日夜夜操| 你懂的日韩| 久久精品免视看国产明星| 久久精品欧美一区二区| 免费一级片在线观看| 久久精品成人一区二区三区| 四虎影视久久久免费| 欧美一区二区三区在线观看| 日本免费乱人伦在线观看 | 精品国产一区二区三区久久久蜜臀| 九九精品久久| 国产91素人搭讪系列天堂| 日韩专区亚洲综合久久| 国产成人精品一区二区视频| 九九精品在线播放| 日本伦理黄色大片在线观看网站| 国产网站免费视频| 成人a大片高清在线观看| 91麻豆国产级在线| 日韩在线观看免费完整版视频| 91麻豆精品国产自产在线| 日本在线不卡视频| 韩国毛片免费| 尤物视频网站在线观看| 九九久久99综合一区二区| 国产一区二区福利久久| 麻豆网站在线看| 黄色福利片| 天天色色网| 欧美电影免费| 久久精品大片| 久久国产影院| 精品久久久久久中文| 欧美电影免费| 日韩在线观看网站| 欧美激情在线精品video| 国产一区二区精品久久91| 午夜激情视频在线观看| 尤物视频网站在线观看| 国产成人欧美一区二区三区的| 国产精品自拍一区| 99久久精品国产高清一区二区| 欧美激情一区二区三区在线播放| 尤物视频网站在线| 成人免费网站久久久| 欧美日本韩国| 国产91视频网| 999久久狠狠免费精品| 日韩在线观看免费完整版视频| 亚洲精品久久玖玖玖玖| 精品视频一区二区|