全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1454
推到 Plurk!
推到 Facebook!

觸發器創建錯誤

答題得分者是:timhuang
h@visli
資深會員


發表:103
回覆:429
積分:431
註冊:2004-02-13

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-06-15 14:12:40 IP:222.248.xxx.xxx 未訂閱
我創建下面觸發器時,提示錯誤,無法創建: CREATE TRIGGER [synhis] ON [dbo].[aaatest] FOR INSERT AS declare @n varchar(50) set @n= replace((convert(varchar(7),getdate(),120)),'-','') insert into @n select * from inserted 錯誤對話方塊: --------------------------- Microsoft SQL-DMO (ODBC SQLState: 42000) --------------------------- 錯誤 137: 必須聲明變數 '@n'。 --------------------------- 確定 ---------------------------
------
------------------------
博采眾家之長,奉獻綿薄之力
------------------------
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-06-15 17:58:21 IP:203.95.xxx.xxx 未訂閱
Hi, 不能用變數組合成 cmd 字串, 要利用 sp_executesql 來執行組合好的 cmd 變數才行, 改為,    CREATE TRIGGER [synhis] ON [dbo].[aaatest]  FOR INSERT AS declare @n varchar(50) declare @cmd nvarchar(800) set @n= replace((convert(varchar(7),getdate(),120)),'-','') set @cmd = 'insert into '+@n+' select * from inserted' exec sp_executesql @cmd 即可!
h@visli
資深會員


發表:103
回覆:429
積分:431
註冊:2004-02-13

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-06-16 12:32:14 IP:222.248.xxx.xxx 未訂閱
引言: Hi, 不能用變數組合成 cmd 字串, 要利用 sp_executesql 來執行組合好的 cmd 變數才行, 改為, CREATE TRIGGER [synhis] ON [dbo].[aaatest] FOR INSERT AS declare @n varchar(50) declare @cmd nvarchar(800) set @n= replace((convert(varchar(7),getdate(),120)),'-','') set @cmd = 'insert into '+@n+' select * from inserted' exec sp_executesql @cmd 即可!
多謝timhuang,現在還有一個問題,就是在插入資料時出現錯誤: --------------------------- SQL Server 企業管理器 --------------------------- [Microsoft][ODBC SQL Server Driver][SQL Server]對象名 'inserted' 無效。 --------------------------- 確定 幫助 ---------------------------
------
------------------------
博采眾家之長,奉獻綿薄之力
------------------------
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-06-16 14:37:53 IP:203.95.xxx.xxx 未訂閱
inserted table 是在 trigger 中才有的一個 logical table , 所以是不能直接在你的 enterprise manager 中執行的哦!
h@visli
資深會員


發表:103
回覆:429
積分:431
註冊:2004-02-13

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-06-20 09:18:43 IP:222.248.xxx.xxx 未訂閱
引言: inserted table 是在 trigger 中才有的一個 logical table , 所以是不能直接在你的 enterprise manager 中執行的哦!
那怎麼辦?觸發器中必須要使用到Inserted哦
------
------------------------
博采眾家之長,奉獻綿薄之力
------------------------
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-06-20 10:39:56 IP:203.95.xxx.xxx 未訂閱
我的意思是在 trigger 中可以用 inserted 沒問題, 但不能直接執行該 trigger 的內容. 不過就弟實測的狀況確實會有這個問題, 在自組的 sql command 中使用這個 logical table 會看不見(應該是 scope 的問題), 但弟用 profiler 追蹤發現確實是同一個 spid, 但為什麼看不到這個 inserted 的 logical table 就很奇怪了, 所以得先用一個 temp table 來解, 至於這個 temp table 是否要 drop 都不影響, 弟實測後發現該 temp table 會自行維護, 即使不 drop 也不會和同一個 spid 的原來源執行指令中的 temp table衝突. (以上皆為在 sql server 2000 的版本下實測). 所以改為, CREATE TRIGGER [synhis] ON [dbo].[aaatest] FOR INSERT AS declare @n varchar(50) declare @cmd nvarchar(800) set @n= replace((convert(varchar(7),getdate(),120)),'-','') set @cmd = 'insert into '+@n+' select * from #tmp_inserted' select * into #tmp_inserted from inserted exec sp_executesql @cmd -- drop table #tmp_inserted <== donesn't matter 發表人 - timhuang 於 2005/06/20 10:41:36
系統時間:2024-07-05 6:54:44
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!