Je suis en train de développer une requête pour renvoyer seulement les enregistrements non-double pour que je puisse ajouter à ma base de données, mais je continue à obtenir cette erreur:Comment formuler T-SQL pour éviter une contrainte de clé primaire?
Msg 2627, Level 14, State 1, Line 1
Violation of PRIMARY KEY constraint 'PK_j5c_MasterMeasures'.
Cannot insert duplicate key in object 'dbo.j5c_MasterMeasures'.
The statement has been terminated.
Et voici ma dernière question que je utilise:
CREATE TABLE #GOOD_RECORDS3 (STUDENTID VARCHAR(50), MEASUREDATE SMALLDATETIME,
measurename VARCHAR(100), LabelName VARCHAR(100), score_10 VARCHAR(100))
INSERT INTO #GOOD_RECORDS3
select A.studentid, A.measuredate, B.measurename, B.LabelName, A.score_10
from [J5C_Measures_Sys] A join [J5C_ListBoxMeasures_Sys] B on
A.MeasureID = B.MeasureID
where score_10 is not null and score_10 <> '0'
except
select A.studentid, A.measuredate, B.measurename, B.LabelName, A.score_10
from [J5C_Measures_Sys] A join [J5C_ListBoxMeasures_Sys] B on
A.MeasureID = B.MeasureID
where score_10 is not null and score_10 <> '0'
GROUP BY A.studentid, A.measuredate, B.measurename, B.LabelName, A.score_10
having COUNT(A.score_10) > 1
delete #GOOD_RECORDS3
from #GOOD_RECORDS3 a
join sysobjects so on so.name = 'J5C_Measures_Sys' AND so.type = 'u'
join syscolumns sc on so.id = sc.id and sc.name = 'score_10'
join [J5C_MeasureNamesV2_Sys] v on v.Score_field_id = sc.name
WHERE A.SCORE_10 IS NOT NULL AND A.STUDENTID IS NOT NULL AND
A.MEASUREID IS NOT NULL
and exists (select 1 from J5C_MasterMeasures M
where M.StudentID = A.StudentID
and M.MeasureID = A.MeasureID)
Insert into J5C_MasterMeasures (studentid, measuredate, measureid, nce)
select A.studentid, A.measuredate, a.MEASUREID, A.score_10
from #GOOD_RECORDS3 a
join sysobjects so on so.name = 'J5C_Measures_Sys' AND so.type = 'u'
join syscolumns sc on so.id = sc.id and sc.name = 'score_10'
join [J5C_MeasureNamesV2_Sys] v on v.Score_field_id = sc.name
WHERE A.SCORE_10 IS NOT NULL AND A.STUDENTID IS NOT NULL AND
A.MEASUREID IS NOT NULL
La partie source de confusion à ce sujet est que MeasureId de M5C_Measures_Sys = B.measurename + ' ' + B.Labelname
. Ceci est quelques exemples de données de #GOOD_RECORDS3
:
1 2006-03-01 00:00:00 ISAT Reading ISAT Reading 564
10005 2003-11-17 00:00:00 TerraNova Reading TerraNova Reading 19
10005 2003-11-17 00:00:00 TerraNova Science TerraNova Science 26
10005 2003-11-17 00:00:00 TerraNova Total Battery TerraNova Total Battery 22
10005 2003-11-17 00:00:00 TerraNova Total Language TerraNova Total Language 43
vous pouvez donc voir que b.measurename = b.labelname
. L'erreur ci-dessus se produit sur l'insertion.
Résultat de votre recherche de réponse ci-dessous:
1 2006-03-01 00:00:00 ISAT Reading ISAT Reading 564
10005 2003-11-17 00:00:00 TerraNova Reading TerraNova Reading 19
10005 2003-11-17 00:00:00 TerraNova Science TerraNova Science 26
10005 2003-11-17 00:00:00 TerraNova Total Battery TerraNova Total Battery 22
10005 2003-11-17 00:00:00 TerraNova Total Language TerraNova Total Language 43
Un peu confus Quelle est la clé primaire? – u07ch
sont les enregistrements exactes en double ou est-ce juste les valeurs dans le champ PK qui sont similaires – zeocrash