;
下一段代码是来获取当前跟踪文件的路径。在相应的文件夹下可能会有多个以log_开头的trace文件,我们可以把这些文件载入一个表中,进行分析,但载入多个文件会增加开销。最好只是载入需要分析的信息。
select * from ::fn_trace_getinfo(0)
现在让我们看一看跟踪下来的数据。我们先从创建一个新数据库开始。
use master
create database TraceDB
使用如下的代码来打开跟踪文件,获取创建数据库的信息。这里使用了一些限制性的条件来缩小结果集。
注意:你的跟踪文件路径和名称可能和我的不同。要使用你自己的跟踪路径。
select
loginname,
loginsid,
spid,
hostname,
applicationname,
servername,
databasename,
objectname,
e.category_id,
cat.name as [CategoryName],
textdata,
starttime,
eventclass,
eventsubclass, --0表示begin,1表示commit
e.name as EventName
from ::fn_trace_gettable('C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\LOG\log.trc',0)
inner join sys.trace_events e
on eventclass = trace_event_id
inner join sys.trace_categories as cat
on e.category_id = cat.category_id
where databasename = 'TraceDB' and
objectname is null and --根据objectname来过滤
e.category_id = 5 and --category 5表示对象
e.trace_event_id = 46 --trace_event_id: 46表示Create对象,47表示Drop对象,164表示修改对象
你能看到超过一条的结果,这是因为捕捉到了2事件子类,begin和commit。
现在创建另一个对象并再次进行查询。这次我们创建一张表“MyTable”。
use TraceDB
create table dbo.MyTable(
id int identity(1,1) not null,
sometext char(3) null
) on primary
现在使用类似的脚本来查询Default Trace,对where条件部分进行修改。
where databasename = 'TraceDB' and
objectname = 'MyTable' and
e.category_id = 5 and
e.trace_event_id = 46
我们同样可以修改对象,代码如下:
use TraceDB
alter table MyTable
add col int
使用如下的条件来过滤查询,特别注意修改trace_event_id为164,因为164代表对象修改事件
where databasename = 'TraceDB' and
objectname = 'MyTable' and
e.category_id = 5 and
e.trace_event_id = 164
最后我们可以把"MyTable"Drop掉。
use TraceDB
drop table MyTable
使用如下的条件来过滤查询,注意修改trace_event_id为47,因为47代表对象删除事件
where databasename = 'TraceDB' and
objectname = 'MyTable' and
e.category_id = 5 and
e.trace_event_id = 47