sql操作日誌
這可能是因為該資料庫: 處於可疑模式。 不再存在。 處於單用戶模式,並且唯一可用的連接已由其他用戶或事物使用。 已被分離。 已設置為 RESTRICTED_USER 狀態。 處於離線狀態。 設置為緊急狀態。 不具有映射到用戶的登錄帳戶,或者該用戶已被拒絕訪問。 此外,該登錄帳戶可能是多個組的成員,且其中一個組的默認資料庫在連接時不可用。 SQL Server 2005 在 SQL Server 2005 中,可以使用 sqlcmd 實用程序更改默認資料庫。為此,請按照下列步驟操作: 1. 單擊「開始」,單擊「運行」,鍵入 cmd,然後按 Enter。 2. 根據 SQL Server 登錄使用的身份驗證種類,請使用以下方法之一: 如果 SQL Server 登錄使用 Microsoft Windows 身份驗證連接到該實例,請在命令提示符處鍵入以下內容,然後按 Enter: sqlcmd –E -S InstanceName –d master 如果 SQL Server 登錄使用 SQL Server 身份驗證連接到該實例,請在命令提示符處鍵入以下內容,然後按 Enter: sqlcmd -S InstanceName -d master -U SQLLogin -P Password 注意:InstanceName 是要連接到的 SQL Server 2005 實例的名稱的佔位符。SQLLogin 是已刪除其默認資料庫的 SQL Server 登錄的佔位符。Password 是 SQL Server 登錄密碼的佔位符。 3. 在 sqlcmd 提示符處,鍵入以下內容,然後按 Enter: Alter LOGIN SQLLogin WITH DEFAULT_DATABASE = AvailDBName 注意:AvailDBName 是可由實例中 SQL Server 登錄訪問的現有資料庫的名稱的佔位符。 4. 在 sqlcmd 提示符處,鍵入 GO,然後按 Enter。 SQL Server 2000 和 SQL Server 7.0 在 SQL Server 2000 和 SQL Server 7.0 中,可以使用 osql 實用程序更改默認資料庫。為此,請按照下列步驟操作: 1. 在命令提示符處,鍵入以下內容,然後按 Enter: C:\>osql -E 2. 在「osql」提示符處,鍵入以下內容,然後按 Enter: 1>sp_defaultdb 'user's_login', 'master' 3. 在第二個提示符處,鍵入以下內容,然後按 Enter: 2>go 更簡單明了的: 無法打開用戶默認資料庫,登錄失敗,這也是SQL Server使用者熟悉的問題之一。在使用企業管理器、查詢分析器、各類工具和應用軟體的時候,只要關繫到連接SQL Server資料庫的時候,都有可能會碰到此問題,引起此錯誤發生的原因比較多,下面我們就來詳細分析引起此問題的原因以及解決辦法。 一、原因 登錄帳戶的默認資料庫被刪除。
❷ sql server日誌查看操作的是哪列
查看sql資料庫操作日誌的方法步驟:1、用windows身份驗證登陸資料庫,點擊【連接】2、展開資料庫伺服器下面的【管理】【SQL Server日誌】3、雙擊【當前】可以打開【日誌文件查看器】裡面有所有的運行日誌
SQL是高級的非過程化編輯語言,允許用戶在高層數據結構上工作。它不要求用戶指定對數據的存放方法,也不需要用戶了解具體的數據存放方式,所以具有完全不同底層結構的不同資料庫系統可以使用相同的sql語言作為數據輸入與管理的介面。
❸ 如何查看SQL server 2008的操作日誌
SQL Server提供了一個undocumented的函數fn_dblog可以讓我們查看活動的transaction log。
語法如下:
::fn_dblog(@StartingLSN,@EndingLSN)
如果參數都為NULL默認是抓取所有的交易信息。
使用這個函數我們可以查詢DML,DDL信息,比如數據刪除,修改更新等等。下面我們來看一個數據更新的例子:
create table test(namevarchar(10))
--插入條數據
insert into testvalues('allen test')
go 5
---查詢對表Test的修改
select [Transaction Name],Operation,AllocUnitId,AllocUnitName,[Begin Time]fromfn_dblog(null,null)
where AllocUnitName ='dbo.test'andOperation='LOP_INSERT_ROWS'
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
NULLLOP_INSERT_ROWS72057594040090624 dbo.test NULL
NULLLOP_INSERT_ROWS72057594040090624 dbo.test NULL
NULLLOP_INSERT_ROWS72057594040090624 dbo.test NULL
NULLLOP_INSERT_ROWS72057594040090624 dbo.test NULL
NULLLOP_INSERT_ROWS72057594040090624 dbo.test
--刪除表
drop table test
----從Log中查詢對表的刪除
select [Transaction Name],Operation,AllocUnitId,AllocUnitName,[Begin Time]fromfn_dblog(null,null)
where [Transaction Name] = 'DROPOBJ'
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
DROPOBJLOP_BEGIN_XACT NULL NULL
--查詢Page Split
select Operation, AllocUnitName,COUNT(*)asNumberofIncidents
from ::fn_dblog(null,null)
where Operation =N'LOP_DELETE_SPLIT'
group byOperation, AllocUnitName
注意:從fn_dblog 查出來的LSN是不能直接作為參數的,需要將16進制轉化為numeric:
The LSN we havefrom the log mp above is 0000009d:0000021e:0001.To convert it:
Take the rightmost 4 characters (2-byte log record number) and convert to a 5-character decimal number, including leading zeroes, to get stringA
Take the middle number (4-byte log block number) and convert to a 10-character decimal number, including leading zeroes, to get stringB
Take the leftmost number (4-byte VLF sequence number) and convert to a decimal number, with no leading zeroes, to get stringC
The LSN string we need is stringC + stringB + stringA
So0000009d:0000021e:0001 becomes '157' + '0000000542'+ '00001' ='157000000054200001'.(來自SQLSkills)
可以參考下面的腳本:
DECLARE @pageID$ NVARCHAR(23), @pageIDNVARCHAR(50), @sqlCmdNVARCHAR(4000);
SET @pageID$ ='0001:0000004d'--- PageID
SELECT @pageID =
CONVERT(VARCHAR(4),CONVERT(INT,CONVERT(VARBINARY,
SUBSTRING(@pageID$, 0, 5), 2)))
+ ',' +
CONVERT(VARCHAR(8),CONVERT(INT,CONVERT(VARBINARY,
SUBSTRING(@pageID$, 6, 8), 2)))
---查看Page內容
SET @sqlCmd = 'DBCC PAGE (''Crack_Me'','+ @pageID + ',3) WITH TABLERESULTS'
EXECUTE(@sqlCmd)
另外這個函數只能對當前活動的Log生效,如果Log備份之後就無法讀取了,我們需要用另外一個函數(fn_mp_dblog http://blog.csdn.net/smithliu328/article/details/7817540)從備份中讀取。上面也只是能夠看到數據被修改,但是無法做到恢復數據。
❹ 如何查看sql資料庫操作日誌
請參照以下步驟查看sql資料庫操作日誌。
1、首先在電腦上打開sql server軟體,進入軟體載入界面。
❺ 如何查看sql數據 操作記錄日誌
方法一:
可以通過執行該命令來查看錯誤日誌信息:exec xp_readerrorlog
方法二:
在SQL SERVER Management Studio中連接該sql server實例,object Explorer中查找Management->SQL Server logs->右鍵選view-》選擇你要看的日誌信息(sql server log or sql server and Windows log)
方法三:
去安裝路徑下去找你的log文件,我的默認實例路徑如下
driver:\SQL Server 2008 R2\MSSQL10_50.MSSQLSERVER\MSSQL\Log\ERRORLOG
❻ 如何查看SQL server 2008的操作日誌
定期分析sqlserver日誌是DBA很重要的任務,那如何才能查看sqlserver日誌呢?
在SQL Server 7.0和SQL Server2000中,可以用下面的命令查看:
DBCC log ( {dbid|dbname}, [, type={0|1|2|3|4}] )
參數:
Dbid or dbname - 任一資料庫的ID或名字
type - 輸出結果的類型:
0 - 最少信息(operation, context, transaction id)
1 - 更多信息(plus flags, tags, row length)
2 - 非常詳細的信息(plus object name, index name,page id, slot id)
3 - 每種操作的全部信息
4 - 每種操作的全部信息加上該事務的16進制信息
默認 type = 0
要查看MSATER資料庫的事務日誌可以用以下命令:
DBCC log (master)
❼ 如何查看sql資料庫操作日誌
請參照以下步驟查看sql資料庫操作日誌。
1、首先在電腦上打開sql server軟體,進入軟體載入界面。
❽ 如何查看sql資料庫操作日誌
找到SQL
server,點屬性,點開advance選項卡,裡面有個mp
directory
後面那個目錄就是你的日誌文件存放的目錄
這時你復制那個目錄下來,在資源管理器中打開那個目錄,裡面的ERORRLOG就是日誌文件啦,用記事本打開他們,慢慢看吧,希望你找到你要的信息。
❾ SQL統計操作日誌
揮不中,卻握不住,
永遠的過中永遠的煩惱,
點綴你的淚光中
花在陽而的,
為么·永遠蒙蔽的他們的雙眼
❿ 如何查看sql資料庫操作日誌
其實這說起來還是滿復雜的```你這要是看不懂的話``我看你就叫些專業人士來搞吧```你這問題我是按下面漫漫試,試好的 連接到 SQL Server 的實例時收到錯誤消息:「Cannot open user default database」(無法打開用戶默認資料庫) 【全文】原因 用戶默認資料庫在連接時不可用。這可能是因為該資料庫: 處於可疑模式。 不再存在。 處於單用戶模式,並且唯一可用的連接已由其他用戶或事物使用。 已被分離。 已設置為 RESTRICTED_USER 狀態。 處於離線狀態。 設置為緊急狀態。 不具有映射到用戶的登錄帳戶,或者該用戶已被拒絕訪問。 此外,該登錄帳戶可能是多個組的成員,且其中一個組的默認資料庫在連接時不可用。 SQL Server 2005 在 SQL Server 2005 中,可以使用 sqlcmd 實用程序更改默認資料庫。為此,請按照下列步驟操作: 1. 單擊「開始」,單擊「運行」,鍵入 cmd,然後按 Enter。 2. 根據 SQL Server 登錄使用的身份驗證種類,請使用以下方法之一: 如果 SQL Server 登錄使用 Microsoft Windows 身份驗證連接到該實例,請在命令提示符處鍵入以下內容,然後按 Enter: sqlcmd –E -S InstanceName –d master 如果 SQL Server 登錄使用 SQL Server 身份驗證連接到該實例,請在命令提示符處鍵入以下內容,然後按 Enter: sqlcmd -S InstanceName -d master -U SQLLogin -P Password 注意:InstanceName 是要連接到的 SQL Server 2005 實例的名稱的佔位符。SQLLogin 是已刪除其默認資料庫的 SQL Server 登錄的佔位符。Password 是 SQL Server 登錄密碼的佔位符。 3. 在 sqlcmd 提示符處,鍵入以下內容,然後按 Enter: Alter LOGIN SQLLogin WITH DEFAULT_DATABASE = AvailDBName 注意:AvailDBName 是可由實例中 SQL Server 登錄訪問的現有資料庫的名稱的佔位符。 4. 在 sqlcmd 提示符處,鍵入 GO,然後按 Enter。 SQL Server 2000 和 SQL Server 7.0 在 SQL Server 2000 和 SQL Server 7.0 中,可以使用 osql 實用程序更改默認資料庫。為此,請按照下列步驟操作: 1. 在命令提示符處,鍵入以下內容,然後按 Enter: C:\>osql -E 2. 在「osql」提示符處,鍵入以下內容,然後按 Enter: 1>sp_defaultdb 'user's_login', 'master' 3. 在第二個提示符處,鍵入以下內容,然後按 Enter: 2>go 更簡單明了的: 無法打開用戶默認資料庫,登錄失敗,這也是SQL Server使用者熟悉的問題之一。在使用企業管理器、查詢分析器、各類工具和應用軟體的時候,只要關繫到連接SQL Server資料庫的時候,都有可能會碰到此問題,引起此錯誤發生的原因比較多,下面我們就來詳細分析引起此問題的原因以及解決辦法。 一、原因 登錄帳戶的默認資料庫被刪除。 二、解決方法: (1)、使用管理員帳戶修改此帳戶的默認資料庫 1、打開企業管理器,展開伺服器組,然後展開伺服器 2. 展開"安全性",展開登錄,右擊相應的登錄帳戶,從彈出的菜單中選擇,屬性 3、重新選擇此登錄帳戶的默認資料庫 (2)、若沒有其他管理員登錄帳戶,無法在企業管理器里修改,使用isql命令行工具 isql /U"sa" /P"sa的密碼" /d"master" /Q"exec sp_defaultdb N'sa', N'master'" 如果使用Windows驗證方式,使用如下命令: isql /E /d"master" /Q"exec sp_defaultdb N'BUILTIN\Administrators', N'master'" 注:上述isql命令可以直接在命令提示符下輸入。 第二篇: 無法打開用戶默認資料庫 登錄失敗 無法打開用戶默認資料庫,登錄失敗,這也是SQL Server使用者熟悉的問題之一。在使用企業管理器、查詢分析器、各類工具和應用軟體的時候,只要關繫到連接SQL Server資料庫的時候,都有可能會碰到此問題,引起此錯誤發生的原因比較多,下面我們就來詳細分析引起此問題的原因以及解決辦法。 一、原因 登錄帳戶的默認資料庫被刪除。 二、解決方法: (一)、使用管理員帳戶修改此帳戶的默認資料庫 1、打開企業管理器,展開伺服器組,然後展開伺服器 2. 展開"安全性",展開登錄,右擊相應的登錄帳戶,從彈出的菜單中選擇,屬性 3、重新選擇此登錄帳戶的默認資料庫 -- 登錄都沒法,安全性節點似乎沒法打開。 (二)、若沒有其他管理員登錄帳戶,無法在企業管理器里修改,使用isql命令行工具 isql /U"sa" /P"sa的密碼" /d"master" /Q"exec sp_defaultdb N'sa', N'master'" 如果使用Windows驗證方式,使用如下命令: isql /E /d"master" /Q"exec sp_defaultdb N'BUILTIN\Administrators', N'master'" 參考:微軟中文知識庫文章:如何解決 SQL Server 2000 中的連接問題 地址: http://support.microsoft.com/default.aspx?scid=kb;ZH-CN;827422 出現本錯誤的情況一般如下: 將一個資料庫導入MS SQL資料庫中,在企業管理器中,所有任務->還原資料庫—>選擇「從設備」還原,找到資料庫文件「xxx.db」,導入。 報錯:設備激活錯誤,請使用with move選項來標志該文件的有效位置。 解決方法:右鍵點「資料庫」(注意不是某個特定的資料庫)—>所有任務—>還原資料庫—>選擇「從設備」還原,選擇要還原成的資料庫名,然後在選項卡中,選擇現有資料庫上強制還原資料庫,然後在下面修改資料庫還原後的物理路徑,這個路徑要是存在的一個路徑,否則就會出現上面的錯誤,邏輯文件名可以不用改,即可。 只要用不同默認資料庫的用戶登錄就可以了。[--各個用戶的默認資料庫] 編輯SQL Server 注冊,改為SQL Server身份驗證,用sa登錄就可以了 sa的默認資料庫被分離 -> 重裝SQL Server