Как вставить внешние ключи с помощью динамических данных - PullRequest
1 голос
/ 21 марта 2011

У меня проблемы с внешними ключами Dynamic Data и Entity Framework 4.0.Такое ощущение, что есть проблема с ассоциацией сущностей, но я не уверен.У меня есть несколько полей, представляющих внешний ключ на странице вставки.Когда я пытаюсь вставить данные, я получаю сообщение об ошибке. Зависимое свойство в ReferentialConstraint отображается в столбец, созданный хранилищем.Колонка: 'CommentId'

Мои данные являются очень базовыми для многих, рассматриваемый внешний ключ - BookId в таблице комментариев.

Книги

  • BookId
  • BookHref

Комментарии

  • CommentId
  • Пользователь
  • Комментарий
  • BookId

Я создаю FOREIGN KEY со следующим сценарием sql.

ALTER TABLE [dbo].[Comments]  WITH CHECK ADD  CONSTRAINT [FK_Comments_Books] FOREIGN KEY([CommentId])
REFERENCES [dbo].[Books] ([BookId])

Entity Framework Генерирует следующий XML

<EntityType Name="Books">
  <Key>
    <PropertyRef Name="BookId" />
  </Key>
  <Property Name="BookId" Type="int" Nullable="false" StoreGeneratedPattern="Identity" />
  <Property Name="Title" Type="nvarchar" Nullable="false" MaxLength="255" />
  <Property Name="Description" Type="nvarchar" Nullable="false" MaxLength="2000" />
  <Property Name="Abstract" Type="nvarchar" />
  <Property Name="UserName" Type="nvarchar" Nullable="false" MaxLength="255" />
  <Property Name="Image" Type="varbinary(max)" />
  <Property Name="BookContent" Type="varbinary(max)" />
  <Property Name="rowguid" Type="uniqueidentifier" Nullable="false" />
  <Property Name="CreateDate" Type="datetime" />
  <Property Name="ModifiedDate" Type="datetime" />
</EntityType>
<EntityType Name="Comments">
  <Key>
    <PropertyRef Name="CommentId" />
  </Key>
  <Property Name="CommentId" Type="int" Nullable="false" StoreGeneratedPattern="Identity" />
  <Property Name="UserName" Type="nvarchar" Nullable="false" MaxLength="255" />
  <Property Name="UserComment" Type="nvarchar" Nullable="false" />
  <Property Name="BookId" Type="int" Nullable="false" />
</EntityType>
<Association Name="FK_Comments_Books">
  <End Role="Books" Type="BookStoreModel.Store.Books" Multiplicity="1" />
  <End Role="Comments" Type="BookStoreModel.Store.Comments" Multiplicity="0..1" />
  <ReferentialConstraint>
    <Principal Role="Books">
      <PropertyRef Name="BookId" />
    </Principal>
    <Dependent Role="Comments">
      <PropertyRef Name="CommentId" />
    </Dependent>
  </ReferentialConstraint>
</Association>

Когда я позволяю скаффолдингу выполнять еговещь, я получаю несколько полей, представляющих внешний ключ Dynamic Data Output for Comments

1 Ответ

0 голосов
/ 21 марта 2011

Я считаю, что FK должно быть:

ALTER TABLE [dbo].[Comments]  WITH CHECK 
ADD  CONSTRAINT [FK_Comments_Books] FOREIGN KEY([BookId])
REFERENCES [dbo].[Books] ([BookId])

Вы определили его для CommentId, который создает отношение 1: 1 между Comment и Book и вашим столбцом BookId в Commentне используется вообще.

...