Подтвердить что ты не робот

Любой, кто использует инфраструктуру Entity Framework * Well *?

Кто-нибудь действительно отправил проект Entity Framework, который делает сопоставление O/R в концептуальные классы, которые сильно отличаются от таблиц в хранилище данных?

Я имею в виду таблицы коллапса (M: M) в другие объекты, чтобы сформировать классы Концептуальные, которые существуют в бизнес-домене, но организованы как несколько таблиц в хранилище данных. Все примеры, которые я вижу в MSDN, мало используют наследование, сворачивают таблицы переходов в другие сущности или сворачивают таблицы поиска в сущности.

Мне бы хотелось услышать или увидеть примеры ниже, которые поддерживают все операции CRUD, которые вы обычно ожидаете делать на бизнес-объекте.:

  • Стол автомобиля и таблица цветов. Цвет может отображаться во многих транспортных средствах (1: M). Они образуют концептуальный класс UsedCar, который имеет свойство Color.

  • Таблицы "Доктор", "Врач-пациенты" и "Пациенты" (от многих до многих). У врачей много пациентов, у пациентов может быть много врачей (M: M). Выделите два концептуальных класса Doctor (у которых есть коллекция пациентов) и пациенты (у которых есть коллекция врачей).

Кто-нибудь видел/делал это с CSDL и SSDL в платформе Entity Framework? CSDL не годится, если он не имеет никакого отношения к чему-либо!

4b9b3361

Ответ 1

Я попытался использовать Entity Framework для существующего проекта (~ 60 таблиц, 3 с наследованием), чтобы посмотреть, что это такое. Мой опыт сводился к:

Поверхность конструктора является kludgy. Отображение не является интуитивным, и кто-то должен был подумать, что одновременное открытие нескольких окон инструмента является приемлемым. Потребовалось много времени, чтобы вручную создать объект и отобразить правильные поля - тогда все еще было странно разговаривать с ним из кода. Несмотря на то, что что-то, что обрабатывает связь с базой данных, имеет важное значение, я считаю, что передача контроля над EF была гораздо более драматичной, чем ручная работа.

Иногда дизайнер просто не загружается, пока вы не перезапустите Visual Studio. Я уверен, что его просто ошибка, но перезагрузка VS раздражает.

Вся ваша работа заканчивается в одном файле, Id ненавидит сливать несколько выпусков разработчиков.

Результирующий SQL (наблюдаемый через Profiler) не был очень хорошим. Я не очень разбираюсь в том, почему, но вам придется писать что-то хуже с первой попытки.

Ответ 3

Ты имеешь в виду вот это?

<edmx:ConceptualModels>
  <Schema xmlns="http://schemas.microsoft.com/ado/2006/04/edm" Namespace="Model1" Alias="Self">
    <EntityContainer Name="Model1Container" >
      <EntitySet Name="ColorSet" EntityType="Model1.Color" />
      <EntitySet Name="DoctorSet" EntityType="Model1.Doctor" />
      <EntitySet Name="PatientSet" EntityType="Model1.Patient" />
      <EntitySet Name="UsedCarSet" EntityType="Model1.UsedCar" />
      <AssociationSet Name="Vehicle_Color" Association="Model1.Vehicle_Color">
        <End Role="Colors" EntitySet="ColorSet" />
        <End Role="Vehicles" EntitySet="UsedCarSet" /></AssociationSet>
      <AssociationSet Name="DoctorPatient" Association="Model1.DoctorPatient">
        <End Role="Doctor" EntitySet="DoctorSet" />
        <End Role="Patient" EntitySet="PatientSet" /></AssociationSet>
      </EntityContainer>
    <EntityType Name="Color">
      <Key>
        <PropertyRef Name="ColorID" /></Key>
      <Property Name="ColorID" Type="Int32" Nullable="false" />
      <NavigationProperty Name="Vehicles" Relationship="Model1.Vehicle_Color" FromRole="Colors" ToRole="Vehicles" /></EntityType>
    <EntityType Name="Doctor">
      <Key>
        <PropertyRef Name="DoctorID" /></Key>
      <Property Name="DoctorID" Type="Int32" Nullable="false" />
      <NavigationProperty Name="Patients" Relationship="Model1.DoctorPatient" FromRole="Doctor" ToRole="Patient" /></EntityType>
    <EntityType Name="Patient">
      <Key>
        <PropertyRef Name="PatientID" /></Key>
      <Property Name="PatientID" Type="Int32" Nullable="false" />
      <NavigationProperty Name="Doctors" Relationship="Model1.DoctorPatient" FromRole="Patient" ToRole="Doctor" />
      </EntityType>
    <EntityType Name="UsedCar">
      <Key>
        <PropertyRef Name="VehicleID" /></Key>
      <Property Name="VehicleID" Type="Int32" Nullable="false" />
      <NavigationProperty Name="Color" Relationship="Model1.Vehicle_Color" FromRole="Vehicles" ToRole="Colors" /></EntityType>
    <Association Name="Vehicle_Color">
      <End Type="Model1.Color" Role="Colors" Multiplicity="1" />
      <End Type="Model1.UsedCar" Role="Vehicles" Multiplicity="*" /></Association>
    <Association Name="DoctorPatient">
      <End Type="Model1.Doctor" Role="Doctor" Multiplicity="*" />
      <End Type="Model1.Patient" Role="Patient" Multiplicity="*" /></Association>
    </Schema>
</edmx:ConceptualModels>