SQL Server 存儲過程遇到“表 '#TT' 沒有標識屬性。無法執行 SET 操作”錯誤


創建臨時表,往臨時表插入數據的時候報的錯誤。

一開始提示沒有打開主鍵,后來打開主鍵就提示上述錯誤異常。

從網上查找資料沒有找到,然后又到群里問各位大牛,一位大牛告訴我是沒有設置主鍵。

我又仔細看看提示,恍然大悟,我就給臨時設置了主鍵。

沒有主鍵之前的代碼:

CREATE TABLE #TT(
    CourseId INT ,
    UserId INT,
    ClassId INT
)
INSERT
INTO
    #TT
( CourseId, UserId, ClassId )
SELECT                         
    CourseId,
    UserId ,
    ClassId
FROM dbo.T_MyOrder

執行的話就會報“表 '#TT' 沒有標識屬性。無法執行 SET 操作”錯誤

修改之后代碼:

CREATE TABLE #TT(
    CourseId INT PRIMARY KEY ,
    UserId INT,
    ClassId INT
)
INSERT
INTO
    #TT
( CourseId, UserId, ClassId )
SELECT                         
    CourseId,
    UserId ,
    ClassId
FROM dbo.T_MyOrder

不報錯了。

然后我又把PRIMARY KEY這個關鍵字去掉了,SqlServer又不報錯了。我現在也不知道咋回事了!

茫然中…………希望有人能給我個建議

 

--2016.08.18 17:29

最近又報錯了,然后我又在插入臨時表之前加上一句話

SET IDENTITY_INSERT #Course ON  --這一句代碼是我剛加的
INSERT
INTO
#Course(CourseId)
SELECT
    CourseId
FROM
    #TT
WHERE
    CourseId > 0

這樣又沒事了

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM