日期:2014-05-17  浏览次数:20473 次

表使用触发器验证数据,在用INSTEAD OF 时,无法写入数据
这是触发器,其中remark字段 是ntext类型,在写入数据时,如果  remark字段中含有"karlpaydayloans.com" 字符串,则输入数据中止,事务回退,但remark字段不包括 "karlpaydayloans.com" 字符串时,执行插入成功,但数据没有写入数据库,请高手看一下

create trigger [tr_table_insertupdate] on tableName
INSTEAD OF  insert,update  
as 
 if exists ( select 1 from inserted  where remark like '%karlpaydayloans.com%' )  
begin  
RAISERROR ('不能修改或者添加',16,1);  
ROLLBACK TRANSACTION  
end 
insert 数据库 触发器

------解决方案--------------------
instead 的意思就是替换掉,触发器里面你不显示插入,就不会再插入数据了。所以这里应该加一个else处理插入。
------解决方案--------------------
1L说的对加上else处理

else if exists(select 1 from deleted) begin
update tb set col1=a.col1,col2=a.col2... from deleted a where tb.id=a.id
end
else begin
insert into tb select * from inserted
end
------解决方案--------------------
换成after 触发器即可,你这个需求不应该使用instead of 触发器
------解决方案--------------------
这感觉有点和尚买梳子的意思啊。

通常都会在插入的时候就判断是否应该插入。
------解决方案--------------------
试着分析下楼主你的逻辑:

关于insert,录入的那部分是不包含你所指字符串的数据;
关于update,更新的那部分也是不包含所指字符串的数据;

那么,首先区分下执行的操作是insert还是update

if not exists (select 1 from deleted)
begin
insert into 表(所有字段)
select 所有字段
from inserted
where charindex('karlpaydayloans.com',remark) = 0
end
else
begin
update a
set a.col = b.col,....
from 表 a join inserted b on a.主键列 = b.主键列
where charindex('karlpaydayloans.com',b.remark) = 0
end

关于提示的部分,个人建议可以做一个日志表将提示的东西存进去,或者不用提示,做好数据的规整就可以。