很多开发人员,包括数据库管理员都有马失前蹄的时候,update/delete时忘记了添加where条件,导致不必要的麻烦。一旦失误,必须要尝试各种恢复手段来恢复数据,尤其是正在使用的生产数据库,造成的影响可想而知,有些新手估计都要吓哭了。。。
如下,用触发器来避免这样的误操作,当然故意为之,不再此讨论范围:
1 use DBName 2 if (object_id('tgr_XX_Where_Clause', 'tr') is not null) 3 drop trigger tgr_XX_Where_Clause 4 go 5 CREATE TRIGGER tgr_XX_Where_Clause 6 ON [Tabel_Name] 7 FOR UPDATE,DELETE 8 AS 9 BEGIN 10 create table #test (eventype varchar(max), parameters varchar(max), Eventinfo varchar(max)) 11 insert #test 12 exec ('dbcc inputbuffer (@@SPID)') 13 IF NOT EXISTS ( SELECT 1 FROM #test where Eventinfo like '% WHERE %' or (Eventinfo not like '%update %' and Eventinfo not like '%delete %')) --检测更新、删除指令必须带where,除出调用存储过程的情况,还有一个情况要排除(insert时有触发器执行了,dbcc inputbuffer只能抓取原始指令而抓不到触发器数据)
BEGIN 15 RAISERROR('USE A WHERE CLAUSE DUMMY', 0, 1) WITH NOWAIT 16 ROLLBACK 17 END 18 END