我遇到了一个问题,我无法使用3rh表的外键将数据从一个表插入到另一个表中。同时保持数据的独特性。
首先,我从临时表中填充我的[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的数据,但这些仍然包含重复项。我要做的是将所有记录插入包含基于Fout表FoutId列匹配的限制的表中,从而过滤掉重复的记录。但是在ExtraInfo表中,FoutId与Value
结合使用时不会有重复记录例如:
[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个重复记录。
我尝试改变第一个表达式,因为它允许不同的行,你可以选择哪些列计数。这并不是一件很大的成功。
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))
INSERT语句与FOREIGN KEY约束冲突 “FK_ExtraInfo_Fouten”。冲突发生在数据库中 “TestDatabase”,表“dbo.Fouten”,列'FoutId'。声明有 已被终止。
我假设这是因为它试图添加一个未在[Fouten]表中列出的FoutId的行。我的查询中的含义是错误的,但无法弄清楚是什么。
任何人都知道如何解决这个问题?非常感谢所有的帮助!
答案 0 :(得分:0)
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 a.FoutId in (select b.FoutId from [TestDatabase].[dbo].Fouten as b where a.FoutId = b.FoutId)
AND NOT EXISTS (SELECT 1
FROM [TestDatabase].[dbo].ExtraInfo t2
WHERE t2.FoutId = a.FoutId
AND t2.Value = a.Value
)