我想使用查询变量中的插入表在插入时创建触发器,如下所示
SET @strTemp = 'INSERT INTO '+@LeadTable+'(service_id,
batch_no,
phone1,
userid,
tt_no
,complaint_id)
select inserted.ProcId,''' + @szBatchName + ''',Right(inserted.Phone,11),inserted.UserId,inserted.TtNo,inserted.ComplaintId from inserted'
此代码未在目标表中插入数据。我想知道如何实现这一目标?请帮忙。谢谢你
这是我的实际代码bt它不起作用
USE [LeadDTB]
alter TRIGGER [dbo].[Push_SibelRealTimeData]
on [dbo].[SibelRealTimeData]
After Insert
AS
BEGIN
DECLARE @szProcId varchar(20)
DECLARE @szUserId varchar(50)
DECLARE @szTtNo varchar(15)
DECLARE @szComplaintId varchar(50)
DECLARE @szPhone varchar(50)
Declare @szBatchName varchar(50)
Declare @LeadDB varchar(50)
Declare @LeadTable varchar(50)
Declare @strTemp varchar(max)
Declare @nBatchCount int
declare @szdialTime varchar(50)
CREATE TABLE #tmTable (id int,procid varchar(50),uid varchar(50),ttno varchar(50),complaintid varchar(50),phone varchar(50))
select * into #tmTable from inserted
select @szdialTime = DATEADD(HOUR, 1, GETDATE())
set @szBatchName = 'SIBELRT_'+CONVERT(varchar(5), right(Year(GETDATE()),2))+Convert(varchar(5),MONTH(GETDATE()))
select @LeadDB = service_db_name from services where service_id =@szProcId
set @LeadTable = @LeadDB+'..LEAD_MASTER_' + @szProcId
SET @strTemp = 'INSERT INTO '+@LeadTable+'(
service_id,
lead_import_batch_id,
lead_phone1,
userid,
tgs_tt_no,
lead_complaint_id
)
select
procid,
''' + @szBatchName + ''',
Right(phone,11),
uid,
ttno,
complaintid from #tmTable '
EXEC(@strTemp)
drop table #tmtable
END
该代码不起作用
SELECT *
INTO #temp
FROM inserted
SET @strTemp = 'INSERT INTO ' + @LeadTable
+ '(service_id,
batch_no,
phone1,
userid,
tt_no,
complaint_id)
select ProcId,''' + @szBatchName
+ ''',Right(Phone,11),UserId,TtNo,ComplaintId from #temp'
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句