방법: 유형별 다중 엔터티 집합으로 모델 정의(Entity Framework)
EDM(엔터티 데이터 모델)을 사용하면 단일 엔터티 컨테이너 내의 여러 엔터티 집합에 하나의 엔터티 형식을 포함하거나 여러 엔터티 컨테이너 내의 엔터티 집합에 하나의 엔터티 형식을 포함할 수 있습니다. MEST(유형별 다중 엔터티 집합)를 정의하면 데이터베이스에 분할이 있거나 여러 테이블의 구조가 동일한 경우에 코드를 효율적으로 사용할 수 있습니다. 자세한 내용은 엔터티 집합(EDM)을 참조하십시오.
MEST 데이터 모델에 대한 개념 스키마를 구현하려면
클래스 라이브러리 프로젝트를 만들고 새 EDM 템플릿을 추가합니다.
동부 지역(CustomersEast) 및 서부 지역(CustomersWest)의 고객을 위한 두 개의 엔터티 집합이 포함된 Customer 엔터티 형식을 구현합니다.
두 지역 고객 엔터티 집합에 사용되는 단일 Customer 엔터티 형식과 OrdersEast 및 OrdersWest 엔터티 집합의 두 주문 형식인 OrderEast 및 OrderWest 간의 차이점을 확인하십시오.
단일 Customer 형식과 두 가지 지역별 주문 형식 OrderEast 및 OrderWest 사이에 연결을 구현하여 MEST 구조를 반영합니다. Customer 형식과 지역별 주문 형식 사이의 두 연결은 모두 카디널리티가 1인 연결 End에서 Customer를 지정합니다.
CSDL(개념 스키마 정의 언어) 스키마에서 Customer 형식이 포함된 두 엔터티 집합을 구현합니다. CustomersEast 및 CustomersWest 엔터티 집합은 모두 RegionalCustomersModel.Customer를 엔터티 형식으로 지정합니다.
<?xml version="1.0" encoding="utf-8"?>
<Schema Namespace="RegionalCustomersModel"
Alias="Self"
xmlns="https://schemas.microsoft.com/ado/2006/04/edm">
<EntityContainer Name="RegionalCustomersEntities">
<EntitySet Name="CustomersEast"
EntityType="RegionalCustomersModel.Customer" />
<EntitySet Name="CustomersWest"
EntityType="RegionalCustomersModel.Customer" />
<EntitySet Name="OrdersEast"
EntityType="RegionalCustomersModel.OrderEast" />
<EntitySet Name="OrdersWest"
EntityType="RegionalCustomersModel.OrderWest" />
<AssociationSet Name="FK_OrderEast_Customer"
Association="RegionalCustomersModel.FK_OrderEast_Customer">
<End Role="Customer" EntitySet="CustomersEast" />
<End Role="OrderEast" EntitySet="OrdersEast" />
</AssociationSet>
<AssociationSet Name="FK_OrderWest_Customer"
Association="RegionalCustomersModel.FK_OrderWest_Customer">
<End Role="Customer" EntitySet="CustomersWest" />
<End Role="OrderWest" EntitySet="OrdersWest" />
</AssociationSet>
</EntityContainer>
<EntityType Name="Customer">
<Key>
<PropertyRef Name="CustomerId" />
</Key>
<Property Name="CustomerId" Type="Int32" Nullable="false" />
<Property Name="Name" Type="String" Nullable="false" />
<Property Name="TotalPurchases" Type="Decimal" Nullable="false" />
<NavigationProperty Name="OrdersEast"
Relationship="RegionalCustomersModel.FK_OrderEast_Customer"
FromRole="Customer" ToRole="OrderEast" />
<NavigationProperty Name="OrdersWest"
Relationship="RegionalCustomersModel.FK_OrderWest_Customer"
FromRole="Customer" ToRole="OrderWest" />
</EntityType>
<EntityType Name="OrderEast">
<Key>
<PropertyRef Name="OrderId" />
</Key>
<Property Name="OrderId" Type="Int32" Nullable="false" />
<Property Name="OrderTotal"
Type="Decimal" Nullable="false" />
<Property Name="Tax" Type="Decimal" />
<NavigationProperty Name="Customer"
Relationship="RegionalCustomersModel.FK_OrderEast_Customer"
FromRole="OrderEast" ToRole="Customer" />
</EntityType>
<EntityType Name="OrderWest">
<Key>
<PropertyRef Name="OrderId" />
</Key>
<Property Name="OrderId" Type="Int32" Nullable="false" />
<Property Name="OrderTotal" Type="Decimal" Nullable="false" />
<Property Name="Tax" Type="Decimal" />
<NavigationProperty Name="Customer"
Relationship="RegionalCustomersModel.FK_OrderWest_Customer"
FromRole="OrderWest" ToRole="Customer" />
</EntityType>
<Association Name="FK_OrderEast_Customer">
<End Role="Customer"
Type="RegionalCustomersModel.Customer" Multiplicity="1" />
<End Role="OrderEast"
Type="RegionalCustomersModel.OrderEast" Multiplicity="*" />
</Association>
<Association Name="FK_OrderWest_Customer">
<End Role="Customer"
Type="RegionalCustomersModel.Customer" Multiplicity="1" />
<End Role="OrderWest"
Type="RegionalCustomersModel.OrderWest" Multiplicity="*" />
</Association>
</Schema>
MEST 데이터 모델에 대한 저장소 스키마를 구현하려면
CustomerEast 및 CustomerWest에 대한 테이블 각각에 해당하는 별도의 엔터티 형식을 구현합니다.
단일 Customer 엔터티 형식 개념 스키마와 달리 저장소 스키마에는 두 개의 고객 테이블이 있습니다.
<?xml version="1.0" encoding="utf-8"?>
<Schema Namespace="RegionalCustomersModel.Store"
Alias="Self"
Provider="System.Data.SqlClient"
ProviderManifestToken="2005"
xmlns="https://schemas.microsoft.com/ado/2006/04/edm/ssdl">
<EntityContainer Name="dbo">
<EntitySet Name="CustomerEast"
EntityType="RegionalCustomersModel.Store.CustomerEast" />
<EntitySet Name="CustomerWest"
EntityType="RegionalCustomersModel.Store.CustomerWest" />
<EntitySet Name="OrderEast"
EntityType="RegionalCustomersModel.Store.OrderEast" />
<EntitySet Name="OrderWest"
EntityType="RegionalCustomersModel.Store.OrderWest" />
<AssociationSet Name="FK_OrderEast_CustomerEast"
Association="RegionalCustomersModel.Store.FK_OrderEast_CustomerEast">
<End Role="CustomerEast" EntitySet="CustomerEast" />
<End Role="OrderEast" EntitySet="OrderEast" />
</AssociationSet>
<AssociationSet Name="FK_OrderWest_CustomerWest"
Association="RegionalCustomersModel.Store.FK_OrderWest_CustomerWest">
<End Role="CustomerWest" EntitySet="CustomerWest" />
<End Role="OrderWest" EntitySet="OrderWest" />
</AssociationSet>
</EntityContainer>
<EntityType Name="CustomerEast">
<Key>
<PropertyRef Name="CustomerId" />
</Key>
<Property Name="CustomerId" Type="int" Nullable="false" />
<Property Name="Name" Type="nvarchar"
Nullable="false" MaxLength="50" />
<Property Name="TotalPurchases" Type="money" Nullable="false" />
</EntityType>
<EntityType Name="CustomerWest">
<Key>
<PropertyRef Name="CustomerId" />
</Key>
<Property Name="CustomerId" Type="int" Nullable="false" />
<Property Name="Name" Type="nvarchar"
Nullable="false" MaxLength="50" />
<Property Name="TotalPurchases" Type="money" Nullable="false" />
</EntityType>
<EntityType Name="OrderEast">
<Key>
<PropertyRef Name="OrderId" />
</Key>
<Property Name="OrderId" Type="int" Nullable="false" />
<Property Name="CustomerId" Type="int" Nullable="false" />
<Property Name="OrderTotal" Type="money" Nullable="false" />
<Property Name="Tax" Type="money" />
</EntityType>
<EntityType Name="OrderWest">
<Key>
<PropertyRef Name="OrderId" />
</Key>
<Property Name="OrderId" Type="int" Nullable="false" />
<Property Name="CustomerId" Type="int" Nullable="false" />
<Property Name="OrderTotal" Type="money" Nullable="false" />
<Property Name="Tax" Type="money" />
</EntityType>
<Association Name="FK_OrderEast_CustomerEast">
<End Role="CustomerEast"
Type="RegionalCustomersModel.Store.CustomerEast" Multiplicity="1" />
<End Role="OrderEast" Type="RegionalCustomersModel.Store.OrderEast"
Multiplicity="*" />
<ReferentialConstraint>
<Principal Role="CustomerEast">
<PropertyRef Name="CustomerId" />
</Principal>
<Dependent Role="OrderEast">
<PropertyRef Name="CustomerId" />
</Dependent>
</ReferentialConstraint>
</Association>
<Association Name="FK_OrderWest_CustomerWest">
<End Role="CustomerWest"
Type="RegionalCustomersModel.Store.CustomerWest"
Multiplicity="1" />
<End Role="OrderWest"
Type="RegionalCustomersModel.Store.OrderWest"
Multiplicity="*" />
<ReferentialConstraint>
<Principal Role="CustomerWest">
<PropertyRef Name="CustomerId" />
</Principal>
<Dependent Role="OrderWest">
<PropertyRef Name="CustomerId" />
</Dependent>
</ReferentialConstraint>
</Association>
</Schema>
SQL Server Management Studio를 사용하여 데이터베이스를 생성하려면
SQL Server Management Studio에서 다음 스크립트를 사용하여 이 예제와 방법: 형식당 하나의 테이블 상속을 사용하여 모델 정의(Entity Framework) 예제에서 사용되는 데이터베이스를 생성합니다.
파일 메뉴에서 새로 만들기를 가리킨 다음 데이터베이스 엔진 쿼리를 클릭하여 SQL Server Management Studio에서 SchoolData 데이터베이스 및 스키마를 만듭니다.
데이터베이스 엔진에 연결 대화 상자에
localhost
또는 다른 SQL Server 인스턴스의 이름을 입력한 다음 연결을 클릭합니다.다음 Transact-SQL 스크립트를 쿼리 창에 붙여넣은 후 실행을 클릭합니다.
USE [master]
GO
CREATE DATABASE [RegionalCustomersMEST]
GO
USE [RegionalCustomersMEST]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[CustomerWest]') AND type in (N'U'))
BEGIN
CREATE TABLE [dbo].[CustomerWest](
[CustomerId] [int] NOT NULL,
[Name] [nvarchar](50) NOT NULL,
[TotalPurchases] [money] NOT NULL,
CONSTRAINT [PK_CustomerWest] PRIMARY KEY CLUSTERED
(
[CustomerId] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
END
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[CustomerEast]') AND type in (N'U'))
BEGIN
CREATE TABLE [dbo].[CustomerEast](
[CustomerId] [int] NOT NULL,
[Name] [nvarchar](50) NOT NULL,
[TotalPurchases] [money] NOT NULL,
CONSTRAINT [PK_CustomerEast] PRIMARY KEY CLUSTERED
(
[CustomerId] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
END
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[OrderWest]') AND type in (N'U'))
BEGIN
CREATE TABLE [dbo].[OrderWest](
[OrderId] [int] NOT NULL,
[CustomerId] [int] NOT NULL,
[OrderTotal] [money] NOT NULL,
[Tax] [money] NULL,
CONSTRAINT [PK_OrderWest] PRIMARY KEY CLUSTERED
(
[OrderId] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
END
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[OrderEast]') AND type in (N'U'))
BEGIN
CREATE TABLE [dbo].[OrderEast](
[OrderId] [int] NOT NULL,
[CustomerId] [int] NOT NULL,
[OrderTotal] [money] NOT NULL,
[Tax] [money] NULL,
CONSTRAINT [PK_OrderEast] PRIMARY KEY CLUSTERED
(
[OrderId] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
END
GO
IF NOT EXISTS (SELECT * FROM sys.foreign_keys WHERE object_id = OBJECT_ID(N'[dbo].[FK_OrderWest_CustomerWest]') AND parent_object_id = OBJECT_ID(N'[dbo].[OrderWest]'))
ALTER TABLE [dbo].[OrderWest] WITH CHECK ADD CONSTRAINT [FK_OrderWest_CustomerWest] FOREIGN KEY([CustomerId])
REFERENCES [dbo].[CustomerWest] ([CustomerId])
GO
ALTER TABLE [dbo].[OrderWest] CHECK CONSTRAINT [FK_OrderWest_CustomerWest]
GO
IF NOT EXISTS (SELECT * FROM sys.foreign_keys WHERE object_id = OBJECT_ID(N'[dbo].[FK_OrderEast_CustomerEast]') AND parent_object_id = OBJECT_ID(N'[dbo].[OrderEast]'))
ALTER TABLE [dbo].[OrderEast] WITH CHECK ADD CONSTRAINT [FK_OrderEast_CustomerEast] FOREIGN KEY([CustomerId])
REFERENCES [dbo].[CustomerEast] ([CustomerId])
GO
ALTER TABLE [dbo].[OrderEast] CHECK CONSTRAINT [FK_OrderEast_CustomerEast]
MEST 모델에 대한 매핑 사양을 구현하려면
아래와 같이 단일 Customer 엔터티를 CustomerEast 및 CustomerWest에 대한 별도의 테이블에 매핑합니다.
엔터티 컨테이너 매핑에서 CustomersEast 및 CustomersWest에 대한 별도의 엔터티 집합을 확인할 수 있습니다.
<?xml version="1.0" encoding="utf-8"?>
<Mapping Space="C-S"
xmlns="urn:schemas-microsoft-com:windows:storage:mapping:CS">
<EntityContainerMapping
StorageEntityContainer="dbo"
CdmEntityContainer="RegionalCustomersEntities">
<EntitySetMapping Name="CustomersEast">
<EntityTypeMapping TypeName="RegionalCustomersModel.Customer">
<MappingFragment StoreEntitySet="CustomerEast">
<ScalarProperty Name="CustomerId" ColumnName="CustomerId" />
<ScalarProperty Name="Name" ColumnName="Name" />
<ScalarProperty Name="TotalPurchases"
ColumnName="TotalPurchases" />
</MappingFragment>
</EntityTypeMapping>
</EntitySetMapping>
<EntitySetMapping Name="CustomersWest">
<EntityTypeMapping TypeName="RegionalCustomersModel.Customer">
<MappingFragment StoreEntitySet="CustomerWest">
<ScalarProperty Name="CustomerId" ColumnName="CustomerId" />
<ScalarProperty Name="Name" ColumnName="Name" />
<ScalarProperty Name="TotalPurchases"
ColumnName="TotalPurchases" />
</MappingFragment>
</EntityTypeMapping>
</EntitySetMapping>
<EntitySetMapping Name="OrdersEast" StoreEntitySet="OrderEast"
TypeName="RegionalCustomersModel.OrderEast">
<ScalarProperty Name="OrderId" ColumnName="OrderId" />
<ScalarProperty Name="OrderTotal" ColumnName="OrderTotal" />
<ScalarProperty Name="Tax" ColumnName="Tax" />
</EntitySetMapping>
<EntitySetMapping Name="OrdersWest" StoreEntitySet="OrderWest"
TypeName="RegionalCustomersModel.OrderWest">
<ScalarProperty Name="OrderId" ColumnName="OrderId" />
<ScalarProperty Name="OrderTotal" ColumnName="OrderTotal" />
<ScalarProperty Name="Tax" ColumnName="Tax" />
</EntitySetMapping>
<AssociationSetMapping Name="FK_OrderEast_Customer"
TypeName="RegionalCustomersModel.FK_OrderEast_Customer"
StoreEntitySet="OrderEast">
<EndProperty Name="Customer">
<ScalarProperty Name="CustomerId" ColumnName="CustomerId" />
</EndProperty>
<EndProperty Name="OrderEast">
<ScalarProperty Name="OrderId" ColumnName="OrderId" />
</EndProperty>
<Condition ColumnName="CustomerId" IsNull="false" />
</AssociationSetMapping>
<AssociationSetMapping Name="FK_OrderWest_Customer"
TypeName="RegionalCustomersModel.FK_OrderWest_Customer"
StoreEntitySet="OrderWest">
<EndProperty Name="Customer">
<ScalarProperty Name="CustomerId" ColumnName="CustomerId" />
</EndProperty>
<EndProperty Name="OrderWest">
<ScalarProperty Name="OrderId" ColumnName="OrderId" />
</EndProperty>
<Condition ColumnName="CustomerId" IsNull="false" />
</AssociationSetMapping>
</EntityContainerMapping>
</Mapping>
참고 항목
작업
방법: 유형별 다중 엔터티 집합을 사용하여 개체 쿼리 만들기 및 실행(Entity Framework)
방법: 특정 엔터티 집합에 개체 추가(Entity Framework)