SqlServer和Oracle中一些常用的sql语句8-触发器和事务(二)
datetime null
)
create trigger db_DDL_trigger3
on database
for DDL_Database_level_Events
as
begin
declare @log xml
set @log =Eventdata()
insert into 记录日志表(事件,所用语句,操作者,发生时间) values
(
@log.value('(/Event_Instance/EventType)[1]','nvarchar(100)'),
@log.value('(/Event_Instance/TSQLCommand)[1]','nvarchar(2000)'),
Convert(nvarchar(100),Current_user),
Getdate()
)
end
--test
create table db_table2
(
仓库编号 int not null,
仓库号 varchar(50) not null,
城市 varchar(50) not null,
面积 int
)
select * from 记录日志表
------------------------------------------
[sql]
--事务
begin transaction update_data
use db_business
go
update 职工备份 set 姓名='事务修改' where 职工号='zg2'
rollback transaction update_data --回滚
--test
select * from 职工备份
--------------------------
begin transaction update_data
use db_business
go
update 职工备份 set 姓名='事务修改' where 职工号='zg2'
commit transaction update_data --提交
--test
select * from 职工备份