如何將sql執(zhí)行的錯(cuò)誤消息記錄到本地文件中實(shí)現(xiàn)過(guò)程_Mssql數(shù)據(jù)庫(kù)教程
推薦:sql server 2008中的apply運(yùn)算符使用方法sql server 2008中的apply運(yùn)算符使用方法,需要的朋友可以參考一下
其實(shí)大家都知道sql語(yǔ)句的錯(cuò)誤信息都可以在sys.messages表里面找到
如:

如果在執(zhí)行語(yǔ)句在try...catch中 我們可以通過(guò)以下方法獲取錯(cuò)誤信息。sql語(yǔ)句如下:
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
當(dāng)然我這里是故意用RAISERROR再次拋出錯(cuò)誤信息,運(yùn)行結(jié)果如下:

現(xiàn)在我們來(lái)定義一個(gè)存儲(chǔ)過(guò)程,其目的就是往本地文件中寫(xiě)入信息。
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
----------------------------------------
然后執(zhí)行該存儲(chǔ)過(guò)程:
exec UCreateOrAppendTextFile 'C:\Error.log','hello majaing'
如果遇到以下錯(cuò)誤則說(shuō)明Ole Automation Procedures沒(méi)有啟用

需要執(zhí)行以下SQL:
go
sp_configure 'show advanced options', 1;
GO
RECONFIGURE;
GO
sp_configure 'Ole Automation Procedures', 1;
GO
RECONFIGURE;
GO
運(yùn)行即如果如圖:

當(dāng)然這里運(yùn)行存儲(chǔ)過(guò)程之前必須保證 文件是存在的。
最后封裝一個(gè)存儲(chǔ)過(guò)程獲取錯(cuò)誤信息,其腳本如下:
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
執(zhí)行存儲(chǔ)過(guò)程及結(jié)果如下:

以上存儲(chǔ)過(guò)程在MSSQL2005、2012中測(cè)試通過(guò)。
大家都知道目前在文件系統(tǒng)中事務(wù)的實(shí)現(xiàn)還是比較復(fù)雜的,雖然在win7后我們可以用C#實(shí)現(xiàn)文件的事務(wù),但是微軟的分布式事務(wù)Distributed Transaction Coordinator(msdtc)目前也還不支持文件事務(wù)。
這里說(shuō)說(shuō)為什么有這樣的需求吧:目前需要一個(gè)項(xiàng)目用SSIS做數(shù)據(jù)遷移,其中很大部分都是用sql語(yǔ)句實(shí)現(xiàn)的, 如 insert into ....select ... from xxxx.其中原數(shù)據(jù)庫(kù)中難免有什么臟數(shù)據(jù)導(dǎo)致插入失敗,于是我在SSIS中使用msdtc服務(wù),保證數(shù)據(jù)的一致性。雖然SSIS也有錯(cuò)誤處理,但是它只能記錄那個(gè)sql語(yǔ)句有問(wèn)題,而不能記錄具體問(wèn)題。于是我想到把錯(cuò)誤信心記錄報(bào)數(shù)據(jù)庫(kù)表里面,可是當(dāng)遇到問(wèn)題時(shí)事務(wù)會(huì)回滾,表里面根本就沒(méi)有錯(cuò)誤信息。于是乎 只能報(bào)錯(cuò)誤信息記錄到文件中了。
如:




有不對(duì)的地方還請(qǐng)大家拍磚哦!
分享:sql中case語(yǔ)句的用法淺談今天看資料的時(shí)候,看到了sql中使用case的一些使用方法,做個(gè)記錄
- sql 語(yǔ)句練習(xí)與答案
- 深入C++ string.find()函數(shù)的用法總結(jié)
- SQL Server中刪除重復(fù)數(shù)據(jù)的幾個(gè)方法
- sql刪除重復(fù)數(shù)據(jù)的詳細(xì)方法
- SQL SERVER 2000安裝教程圖文詳解
- 使用sql server management studio 2008 無(wú)法查看數(shù)據(jù)庫(kù),提示 無(wú)法為該請(qǐng)求檢索數(shù)據(jù) 錯(cuò)誤916解決方法
- SQLServer日志清空語(yǔ)句(sql2000,sql2005,sql2008)
- Sql Server 2008完全卸載方法(其他版本類(lèi)似)
- sql server 2008 不允許保存更改,您所做的更改要求刪除并重新創(chuàng)建以下表
- SQL Server 2008 清空刪除日志文件(瞬間日志變幾M)
- Win7系統(tǒng)安裝MySQL5.5.21圖解教程
- 將DataTable作為存儲(chǔ)過(guò)程參數(shù)的用法實(shí)例詳解
Mssql數(shù)據(jù)庫(kù)教程Rss訂閱編程教程搜索
Mssql數(shù)據(jù)庫(kù)教程推薦
- Sql學(xué)習(xí)第一天——SQL 將變量定義為T(mén)able類(lèi)型(虛擬表)
- 剖析SQL Server2005 SQLCLR代碼安全性
- SqlServer2005 數(shù)據(jù)庫(kù)同步配置圖文詳解
- 解析SQL Server 2000 SP4與數(shù)據(jù)鏈接池問(wèn)題
- 詳解MSSQL的安全設(shè)置問(wèn)題
- 揭秘SQL Server查詢(xún)優(yōu)化方法
- 揭秘優(yōu)化SQL Server數(shù)據(jù)庫(kù)查詢(xún)的方法
- 談SQL Server應(yīng)用程序的高級(jí)Sql注入
- 揭秘SQL Server開(kāi)發(fā)中需要注意的十個(gè)問(wèn)題
- 解析SQL Server2000連接中三個(gè)最常見(jiàn)錯(cuò)誤
猜你也喜歡看這些
- 網(wǎng)站模板MySQL timestamp自動(dòng)更新時(shí)間
- 關(guān)于MySQL數(shù)據(jù)遷移--data目錄直接替換注意事項(xiàng)的詳解
- 怎么重置mysql的自增列AUTO_INCREMENT初時(shí)值
- PHP mysqli擴(kuò)展庫(kù) 預(yù)處理技術(shù)的使用分析
- Mysql中“Insert into xxx on duplicate key update”問(wèn)題
- MySQL 生成隨機(jī)密碼
- java連接mysql數(shù)據(jù)庫(kù)亂碼怎么辦
- 淺析一個(gè)MYSQL語(yǔ)法(在查詢(xún)中使用count)的兼容性問(wèn)題
- mysql常用設(shè)置:字符集編碼、自動(dòng)完成(自動(dòng)提示)、監(jiān)聽(tīng)外網(wǎng)ip
- MySQL索引簡(jiǎn)單分析
- 相關(guān)鏈接:
復(fù)制本頁(yè)鏈接| 搜索如何將sql執(zhí)行的錯(cuò)誤消息記錄到本地文件中實(shí)現(xiàn)過(guò)程
- 教程說(shuō)明:
Mssql數(shù)據(jù)庫(kù)教程-如何將sql執(zhí)行的錯(cuò)誤消息記錄到本地文件中實(shí)現(xiàn)過(guò)程
。