ошибка ограничения внешнего ключа отладки - PullRequest
0 голосов
/ 30 июля 2011

У меня есть база данных Sql Server, которая была сгенерирована инструментом схемы Nhibernate, и при попытке ввести известный идентификатор PartyId появляется ошибка ниже, и я просто не получаю ошибку.(Даже несмотря на то, что вывод журнала, который я показываю, происходит из тестового прогона с использованием NHibernate, я могу повторить ошибку вручную, используя базу данных SQL Server, сгенерированную NHib)

I думаю ограничение FKговорит, что PartyId должен существовать в первую очередь, но, как я уже сказал, он существует.

У меня есть студия управления SQL Server 2008, но я редко использую его, предпочитая обращаться к нему через Visual Studio в те редкие моменты, когда мне это нужно.Итак, у меня есть два основных вопроса

  • как мне увидеть ddl в sql server из visual studio?
  • как мне отладить и исправить мою проблему с ограничением FK?

DDL, сгенерированный NHib

create table PartyNames (
    PartyNameId INTEGER not null,
   PartyId INTEGER not null,
   RequiredName TEXT not null,
   EverythingElse TEXT,
   ContextUsed TEXT,
   Salutation TEXT,
   EffectiveStart DATETIME,
   EffectiveEnd DATETIME,
   primary key (PartyNameId)
)

create table Parties (
    PartyId INTEGER not null,
   Type TEXT not null,
   primary key (PartyId)
)

ОШИБКА

NHibernate: INSERT INTO Parties (Type, PartyId) VALUES ('PERSON', @p0);@p0 = 98304 [Type: Int32 (0)]
NHibernate: INSERT INTO Parties (Type, PartyId) VALUES ('PERSON', @p0);@p0 = 98305 [Type: Int32 (0)]
NHibernate: INSERT INTO Parties (Type, PartyId) VALUES ('PERSON', @p0);@p0 = 98306 [Type: Int32 (0)]
NHibernate: select next_hi from hibernate_unique_key with (updlock, rowlock)
NHibernate: update hibernate_unique_key set next_hi = @p0 where next_hi = @p1;@p0 = 5 [Type: Int32 (0)], @p1 = 4 [Type: Int32 (0)]
NHibernate: INSERT INTO 
    PartyNames (PartyId, RequiredName, EverythingElse, ContextUsed, Salutation, EffectiveStart, EffectiveEnd, PartyNameId) 
    VALUES (@p0, @p1, @p2, @p3, @p4, @p5, @p6, @p7);
        @p0 = 98304 [Type: Int32 (0)], 
        @p1 = 'Hesh' [Type: String (50)], 
        @p2 = 'Berryl;;;' [Type: String (4000)], 
        @p3 = 'Stack Overflow Profile' [Type: String (50)], 
        @p4 = 'Fellow Geek' [Type: String (20)], 
        @p5 = 7/29/2011 4:55:19 PM [Type: DateTime (0)], 
        @p6 = 12/31/9999 11:59:59 PM [Type: DateTime (0)], 
        @p7 = 131072 [Type: Int32 (0)]
Test 'Parties.Data.Impl.NHib.Tests.TestFixtures.BaseDataTestFixtures.SqlServerCommandExecutor.GenerateTestData' failed: NHibernate.Exceptions.GenericADOException : could not insert: [Parties.Domain.Names.PartyName#131072][SQL: INSERT INTO PartyNames (PartyId, RequiredName, EverythingElse, ContextUsed, Salutation, EffectiveStart, EffectiveEnd, PartyNameId) VALUES (?, ?, ?, ?, ?, ?, ?, ?)]
  ----> System.Data.SqlClient.SqlException : 
  The INSERT statement conflicted with the FOREIGN KEY constraint "Party_PartyName_FK". 
  The conflict occurred in database "PartyDomainDb", table "dbo.Parties", column 'PartyId'.

Создание сценариев

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[PartyNames](
    [PartyNameId] [int] NOT NULL,
    [PartyId] [int] NOT NULL,
    [RequiredName] [nvarchar](50) NOT NULL,
    [EverythingElse] [nvarchar](255) NULL,
    [ContextUsed] [nvarchar](50) NULL,
    [Salutation] [nvarchar](20) NULL,
    [EffectiveStart] [datetime] NULL,
    [EffectiveEnd] [datetime] NULL,
PRIMARY KEY CLUSTERED 
(
    [PartyNameId] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

GO

ALTER TABLE [dbo].[PartyNames]  WITH CHECK ADD  CONSTRAINT [Party_FK] FOREIGN KEY([PartyId])
REFERENCES [dbo].[Parties] ([PartyId])
GO

ALTER TABLE [dbo].[PartyNames] CHECK CONSTRAINT [Party_FK]
GO

ALTER TABLE [dbo].[PartyNames]  WITH CHECK ADD  CONSTRAINT [Party_PartyName_FK] FOREIGN KEY([PartyNameId])
REFERENCES [dbo].[Parties] ([PartyId])
GO

ALTER TABLE [dbo].[PartyNames] CHECK CONSTRAINT [Party_PartyName_FK]
GO

USE [PartyDomainDb]
GO

/****** Object:  Table [dbo].[Parties]    Script Date: 07/29/2011 18:22:29 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[Parties](
    [PartyId] [int] NOT NULL,
    [Type] [nvarchar](255) NOT NULL,
PRIMARY KEY CLUSTERED 
(
    [PartyId] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

GO

1 Ответ

3 голосов
/ 30 июля 2011

Внешний ключ, вероятно, не определен правильно.Это текущее определение.

ALTER TABLE [dbo].[PartyNames]  WITH CHECK ADD  CONSTRAINT [Party_PartyName_FK] FOREIGN KEY([PartyNameId])REFERENCES [dbo].[Parties] ([PartyId])

Вероятно, оно должно быть следующим.

ALTER TABLE [dbo].[PartyNames]  WITH CHECK ADD  CONSTRAINT [Party_PartyName_FK] FOREIGN KEY([PartyId])REFERENCES [dbo].[Parties] ([PartyId])

Обратите внимание, что я поменял PartyNameId на PartyId.

...