sql 触发器 NTEXT TEXT IMAGE 无法写入的问题 二进制来做


instead of  insert,update,delete   以前写的是after =instead of  改这样直接二进制来做





USE [testOAone]

GO
/****** Object:  Trigger [dbo].[tgr_FileMailData]    Script Date: 09/23/2015 14:32:52 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO






ALTER trigger [dbo].[tgr_FileMailData]
on [dbo].[FileMailData]
instead of  insert,update,delete
as
declare @RecUser varchar(8000)
declare @SenderStreetName nvarchar(4000)
declare @SenderGroupName nvarchar(4000)
declare @SenderSectionOffice nvarchar(4000)
declare @SenderID nvarchar(200)
declare @MailTit nvarchar(MAX)
declare @MailText nvarchar(MAX)
declare @SendTime nvarchar(4000)
declare @EFName  nvarchar(4000)
declare @CFName nvarchar(4000)
declare @UserIP nvarchar(4000)
declare @RecUserBak nvarchar(MAX)
declare @RecUserBakID nvarchar(MAX)
declare @OverRead nvarchar(MAX)
declare @OverReadID nvarchar(MAX)
declare @OverRec nvarchar(MAX)
declare @FileClass char(10)
declare @MailState nvarchar(200)
declare @ExamineState int
declare @ExamineType int
declare @ExamineContent nvarchar(MAX)
declare @ReadUser nvarchar(MAX)
declare @Word varchar(200)
declare @WordNO varchar(200)
declare @DraftDepartment varchar(200)
declare @DraftMan varchar(200)
declare @STime datetime
declare @ETime datetime
declare @DBZT varchar(50)
declare @SFDB varchar(50)
declare @BETime datetime


 select @RecUser=RecUser,@SenderStreetName=SenderStreetName,@SenderGroupName=SenderGroupName,
        @SenderSectionOffice=SenderSectionOffice,@SenderID=SenderID,@MailTit=MailTit from inserted
 select @RecUser=RecUser,@SenderStreetName=SenderStreetName,@SenderGroupName=SenderGroupName from deleted
 select @RecUser=RecUser,@SenderStreetName=SenderStreetName,@SenderGroupName=SenderGroupName from updated
    if (exists (select 1 from inserted) )
    begin
        insert into [testOAtwo].[dbo].DZM_FileMailData(RecUser,SenderStreetName,SenderGroupName) 
        values(@RecUser,@SenderStreetName,@SenderGroupName);
    end
    else if (exists (select 1 from deleted))
    begin
        insert into [testOAtwo].[dbo].DZM_FileMailData(RecUser,SenderStreetName,SenderGroupName) 
        values(@RecUser,@SenderStreetName,@SenderGroupName);
    end
    else if (exists (select 1 from updated))
    begin
       insert into [testOAtwo].[dbo].DZM_FileMailData(RecUser,SenderStreetName,SenderGroupName) 
        values(@RecUser,@SenderStreetName,@SenderGroupName);
    end
sqlserver触发器例子 一﹕ 触发器是一种特殊的存储过程﹐它不能被显式地调用﹐而是在往中插入记录﹑更新记录或者删除记录时被自动地激活。所以触发器可以用来实现对实施复杂的完整性约`束。 二﹕ SQL Server为每个触发器都创建了两个专用﹕Inserted和Deleted。这两个由系统来维护﹐它们存在于内存中而不是在数据库中。这两个的结构总是与被该触发器作用的的结构相同。触发器执行 完成后﹐与该触发器相关的这两个也被删除。 Deleted存放由于执行Delete或Update语句而要从中删除的所有行。 Inserted存放由于执行Insert或Update语句而要向中插入的所有行。 三﹕Instead of 和 After触发器 SQL Server2000提供了两种触发器﹕Instead of 和After 触发器。这两种触发器的差别在于他们被激活的同﹕ Instead of触发器用于替代引起触发器执行的T-SQL语句。除之外﹐Instead of 触发器也可以用于视图﹐用来扩展视图可以支持的更新操作。 After触发器在一个Insert,Update或Deleted语句之后执行﹐进行约束检查等动作都在After触发器被激活之前发生。After触发器只能用于。 一个或视图的每一个修改动作(insert,update和delete)都可以有一个instead of 触发器﹐一个的每个修改动作都可以有多个After触发器。 四﹕触发器的执行过程 如果一个Insert﹑update或者delete语句违反了约束﹐那幺After触发器不会执行﹐因为对约束的检查是在After触发器被激动之前发生的。所以After触发器不能超越约束。 Instead of 触发器可以取代激发它的操作来执行。它在Inserted和Deleted刚刚建立﹐其它任何操作还没有发生时被执行。因为Instead of 触发器在约束之前执行﹐所以它可以对约束进行一些预处理。 五﹕使用T-SQL语句来创建触发器 基本语句如下﹕ create trigger trigger_name on {table_name | view_name} {for | After | Instead of } [ insert, update,delete ] as sql_statement 六﹕相关示例﹕ 1﹕在Orders中建立触发器﹐当向Orders中插入一条订单记录时﹐检查goods的货品状态status是否为1(正在整理)﹐是﹐则不能往Orders加入该订单。 create trigger orderinsert on orders after insert as if (select status from goods,inserted where goods.name=inserted.goodsname)=1 begin print 'the goods is being processed' print 'the order cannot be committed' rollback transaction --回滚﹐避免加入 end 2﹕在Orders建立一个插入触发器﹐在添加一条订单时﹐减少Goods相应的货品记录中的库存。 create trigger orderinsert1 on orders after insert as update goods set storage=storage-inserted.quantity from goods,inserted where goods.name=inserted.goodsname 3﹕在Goods建立删除触发器﹐实现Goods和Orders的级联删除。 create trigger goodsdelete on goods after delete as delete from orders where goodsname in (select name from deleted) 4﹕在Orders建立一个更新触发器﹐监视Orders的订单日期(OrderDate)列﹐使其不能手工修改. create trigger orderdateupdate on orders after update as if update(orderdate) begin raiserror(' orderdate cannot be modified',10,1) rollback transaction end 5﹕在Orders建立一个插入触发器﹐保证向Orders插入的货品名必须要在Goods中一定存在。 create trigger orderinsert3 on orders after insert as if (select count(*) from goods,inserted where goods.name=inserted.goodsname)=0 begin print ' no entry in goods for this order' rollback transaction end --insert 触发器 create trigger tri_infoDetails_i on info_details after insert as declare @id int begin --delete from info_details where id= select @id=id from inserted; insert into info_details_index(TYPE,TITLE,content,POST_TIME,FLAG) select type,title,content,getdate(),1 from info_details where id=@id; --update info_details_index set content=content end; -- update触发器 --select top 0 type,title,content,getdate() as post_time,1 as flag into info_details_index from info_details; create trigger tri_infoDetails_u on info_details after update as declare @id int begin if exists(select 1 from inserted) if exists(select 1 from deleted) begin select @id=id from inserted; insert into info_details_index(TYPE,TITLE,content,POST_TIME,FLAG)select type,title,content,getdate(),-1 from info_details where id=@id; insert into info_details_index(TYPE,TITLE,content,POST_TIME,FLAG)select type,title,content,getdate(),1 from info_details where id=@id; end --update info_details_index set content=content end --delete触发器 create trigger tri_infoDetails_d on info_details after delete as declare @id int begin if exists(select 1 from deleted) begin insert into info_details_index(TYPE,TITLE, POST_TIME,FLAG) select type,title, getdate(),-1 from deleted info_details ; end end
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值