SQL:使用外键

时间:2016-04-13 08:38:40

标签: c# sql sql-server foreign-keys sql-insert

我遇到了一个问题,我无法使用3rh表的外键将数据从一个表插入到另一个表中。同时保持数据的独特性。

SQL diagram

首先,我从临时表中填充我的[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的行。我的查询中的含义是错误的,但无法弄清楚是什么。

任何人都知道如何解决这个问题?非常感谢所有的帮助!

1 个答案:

答案 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
                  )