3rhテーブルの外部キーを使用して、あるテーブルから別のテーブルにデータを挿入できないという問題が発生しました。データをユニークに保ちながらSQL:外部キーを持つテーブルへのステージングテーブル
まず私は、ステージング表から私の[Fouten]テーブルを移入します。このクエリフィルタは、残りの行を複製して格納します。行は約144.000行から66.580行になります。これは完璧に動作し、それがはずのよう -
INSERT INTO [TestDatabase].[dbo].Fouten (FoutId, Datum, Time, FoutCode,Omschrijving,TreinId, Module)
SELECT st.FoutId, st.Datum, st.Time, st.FoutCode, st.Omschrijving, st.TreinId, st.Module
FROM (
SELECT FoutId,
Datum,
Time,
FoutCode,
Omschrijving,
TreinId,
Module,
row_number() over (partition by TreinId, Datum, Time, FoutCode order by TreinId, Datum, Time, FoutCode) as rn
FROM [TestDatabase].[dbo].foutenTemp) as st
WHERE st.rn = 1
AND NOT EXISTS (SELECT 1
FROM [TestDatabase].[dbo].Fouten t2
WHERE t2.TreinId = st.TreinId
AND t2.Datum = st.Datum
AND t2.Time = st.Time
AND t2.FoutCode = st.FoutCode)
出力:
[Fouten]
FoutId Datum Time FoutCode Omschrijving Module TreinId
4 2009-11-29 08:59:10.070 01-00-26 Overgang AC naar DC ACTRL1_A9120110 1
5 2009-11-29 21:10:35.612 01-00-27 Overgang DC naar AC ACTRL1_A9120110 1
6 2009-11-30 12:29:56.638 01-00-26 Overgang AC naar DC ACTRL1_A9120110 1
10 2009-12-01 06:17:57.048 01-00-26 Overgang AC naar DC ACTRL1_A9120110 1
15 2009-12-01 05:34:06.779 06-00-46 Def. of incoh. richtwaarde voor blending ACTRL1_A9120110 1
FoutIdの中間に取り出してしまった重複のものされて行方不明。
FoutIdのExtraInfoに関するデータを含む2番目のステージングテーブルが作成されましたが、これらには重複が含まれています。私がしようとしているのは、FoutテーブルFoutId列の一致に基づいて制限を含むすべてのレコードをテーブルに挿入し、重複するレコードをフィルタリングすることです。しかし、テーブル内とextrainfoは、例えばので価値
と組み合わせるFoutIdため、重複するレコードが存在することはできません。
[ExtraInfo]
FoutId Value
3 etat_x_convoi_ok = 0x01 ''
3 old_mode_ac_dc = 0
3 ICO_m_a_pmcf = 0
3 APP_mode_ac_dc = 0x01 ''
4 etat_x_convoi_ok = 0x01 ''
4 old_mode_ac_dc = 16777216
4 old_mode_ac_dc = 16777216
4 ICO_m_a_pmcf = 0
4 APP_mode_ac_dc = 0x00 '
4 APP_mode_ac_dc = 0x00 '
はなるはずです。
[ExtraInfo]
FoutId Value
4 etat_x_convoi_ok = 0x01 ''
4 old_mode_ac_dc = 16777216
4 ICO_m_a_pmcf = 0
4 APP_mode_ac_dc = 0x00 '
FoutIdが存在することがあるので[Fouten]テーブルでは、4を含まないFoutIdを削除する必要があります。また、値4と重複したレコードを削除する必要があります。
最初の式を変更しようとしました。なぜなら、uがどの列をカウントするかを選択できる別個の行を許可するからです。これは大成功ではありませんでした。
INSERT INTO [TestDatabase].[dbo].ExtraInfo (FoutId, Value)
SELECT a.FoutId, a.Value
FROM (
SELECT FoutId,
Value,
row_number() over (partition by FoutId, Value order by FoutId, Value) as rn
FROM [TestDatabase].[dbo].extrainfoTemp) as a
WHERE a.rn = 1
AND NOT EXISTS (SELECT 1
FROM [TestDatabase].[dbo].ExtraInfo t2
WHERE t2.FoutId in (
select t1.FoutId from [TestDatabase].[dbo].Fouten t1 where t1.FoutId = t2.FoutId))
FOREIGN KEY制約 "FK_ExtraInfo_Fouten" と競合INSERT文。競合はデータベース "TestDatabase"、テーブル "dbo.Fouten"、列 'FoutId'で発生しました。ステートメントには が終了しました。
[Fouten]テーブル内にリストされていないFoutIdを含む行を追加しようとしているためです。私の質問の意味は間違っていますが、何が分かりませんか。
これを解決する方法はありますか?すべての助けが大いに評価されます!