逐步解說:建立 N-Tier 資料應用程式
「多層式架構」(N-tier) 資料應用程式是可存取資料而且分成多個邏輯層或「層級」(tier) 的應用程式。 將應用程式元件分成離散層級,可增加應用程式的可維護性和延展性。 原因是可以更輕鬆地採用套用至單一層級的新技術,而且您不需要重新設計整個方案。 多層式架構包括呈現層、中介層和資料層。 中介層通常包括資料存取層、商務邏輯層和共用元件 (如驗證 (authentication) 和驗證 (validation))。 資料層包括關聯式資料庫。 多層式架構應用程式通常會將敏感性資訊儲存至中介層的資料存取層,以與存取呈現層的使用者隔離。 如需詳細資訊,請參閱多層式架構資料應用程式概觀。
其中一種在多層式架構應用程式中分為各種層級的方式,是針對您要併入應用程式中的每個層級建立離散專案。 具類型資料集所含的 DataSet Project 屬性可以決定所產生的資料集和 TableAdapter 程式碼應該進入的專案。
此逐步解說示範如何使用 [DataSet 設計工具] 將資料集和 TableAdapter 程式碼分成離散類別庫專案。 在您分隔資料集和 TableAdapter 程式碼之後,將會建立要呼叫到資料存取層的 Visual Studio 中的 Windows Communication Foundation 服務和 WCF 資料服務 服務。 最後,您將建立 Windows Form 應用程式做為呈現層。 此層級會存取資料服務中的資料。
在這個逐步解說期間,您將執行下列步驟:
建立含有多個專案的新多層式架構方案。
將兩個類別庫專案加入至多層式架構方案。
使用 [資料來源組態精靈],以建立具類型資料集。
將產生的 TableAdapter 和資料集程式碼分成離散專案。
建立要呼叫到資料存取層的 Windows Communication Foundation (WCF) 服務。
在服務中建立函式,以擷取資料存取層中的資料。
建立 Windows Form 應用程式,以做為呈現層。
建立繫結至資料來源的 Windows Form 控制項。
撰寫程式碼以填入資料表。
如需本主題的影片版本,請參閱影片 - 如何:建立多層式架構資料應用程式。
必要條件
若要完成這個逐步解說,您需要:
- Northwind 範例資料庫的存取權。 如需詳細資訊,請參閱如何:安裝範例資料庫。
建立多層式架構方案和類別庫以保留資料集 (DataEntityTier)
這個逐步解說的第一個步驟是建立一個方案和兩個類別庫專案。 第一個類別庫將會保留資料集 (產生的具類型 DataSet 類別以及將保留應用程式資料的 DataTables)。 此專案是用做應用程式的資料實體層,而且通常位於中介層。 建立和編輯具類型資料集是用來建立初始資料集,而且會自動將程式碼分成兩個類別庫。
注意事項 |
---|
請一定要先正確地命名專案和方案,再按一下 [確定]。這麼做可以讓您輕鬆地完成這個逐步解說。 |
建立多層式架構方案和 DataEntityTier 類別庫
從 [檔案] 功能表中,建立新專案。
注意事項 Visual Basic 和 C# 專案中支援 [DataSet 設計工具]。請使用下列其中一種語言,來建立新的專案。
在 [新增專案] 對話方塊的 [專案類型] 中,按一下 [Windows]。
按一下 [類別庫] 範本。
將專案命名為 DataEntityTier。
將方案命名為 NTierWalkthrough。
按一下 [確定]。
隨即建立含有 DataEntityTier 專案的 NTierWalkthrough 方案,並將它加入至 [方案總管]。
建立類別庫以保留 TableAdapter (DataAccessTier)
建立 DataEntityTier 專案之後的下一個步驟是建立另一個類別庫專案。 此專案將保留產生的 TableAdapter,而且稱為應用程式的「資料存取層」(data access tier)。 資料存取層包含連接至資料庫所需的資訊,而且通常位於中介層。
建立 TableAdapter 的新類別庫
從 [檔案] 功能表中,將新的專案加入至 NTierWalkthrough 方案。
在 [新增專案] 對話方塊中,按一下 [範本] 窗格中的 [類別庫]。
將專案命名為 DataAccessTier,然後按一下 [確定]。
隨即建立 DataAccessTier 專案,並將它加入至 NTierWalkthrough 方案。
建立資料集
下一個步驟是建立具類型資料集。 在單一專案中,建立具有資料集類別 (包括 DataTables 類別) 和 TableAdapter 類別的具類型資料集 (所有類別都會產生到單一檔案)。當您將資料集和 TableAdapter 分隔到不同的專案時,是將資料集類別移至另一個專案,而 TableAdapter 類別會保留在原始專案中。 因此,在最後會包含 TableAdapter 的專案 (DataAccessTier 專案) 中建立資料集。 您將使用 [資料來源組態精靈] 來建立資料集。
注意事項 |
---|
您必須具有 Northwind 範例資料庫的存取權,才能建立連接。如需如何設定 Northwind 範例資料庫的詳細資訊,請參閱如何:安裝範例資料庫。 |
建立資料集
按一下 [方案總管] 中的 [DataAccessTier]。
按一下 [資料] 功能表上的 [顯示資料來源]。
在 [資料來源] 視窗中,按一下 [加入新資料來源] 啟動 [資料來源組態精靈]。
在 [選擇資料來源類型] 頁面上,按一下 [資料庫],再按 [下一步]。
在 [選擇資料連接] 頁面上,執行下列其中一項動作:
如果下拉式清單中提供 Northwind 範例資料庫的資料連接,請按一下這個資料連接。
-或-
按一下 [新增連接] 開啟 [新增連接] 對話方塊。
如果資料庫需要密碼,請選取選項來加入敏感性資料,然後按 [下一步]。
注意事項 如果您已選取本機資料庫檔案 (而非連接至 SQL Server),則系統可能會詢問您是否要將檔案加入至專案。按一下 [是],將資料庫檔案加入至專案。
在 [將連接字串儲存到應用程式組態檔] 頁面上,按一下 [下一步]。
在 [選擇您的資料庫物件] 頁面上,展開 [資料表] 節點。
按一下 Customers和 Orders資料表的核取方塊,再按一下 [完成]。
NorthwindDataSet 會加入至 DataAccessTier 專案,並出現在 [資料來源] 視窗中。
分隔 TableAdapter 與資料集
在您建立資料集之後,請分隔產生的資料集類別與 TableAdapter。 做法是將 [資料集專案] 屬性設定為在其中儲存分開之資料集類別的專案名稱。
分隔 TableAdapter 與資料集
在 [方案總管] 中,按兩下 [NorthwindDataSet.xsd] 開啟 [DataSet 設計工具]。
按一下設計工具上的空白區域。
在 [屬性] 視窗中,找到 [資料集專案] 節點。
在 [資料集專案] 清單中,按一下 [DataEntityTier]。
在 [建置] 功能表上,按一下 [建置方案]。
資料集和 TableAdapter 會分隔到兩個類別庫專案。 原本包含整個資料集的專案 (DataAccessTier) 現在只會包含 TableAdapter。 [資料集專案] 屬性中指定的專案 (DataEntityTier) 包含具類型資料集:NorthwindDataSet.Dataset.Designer.vb (或 NorthwindDataSet.Dataset.Designer.cs)。
注意事項 |
---|
當您分隔資料集與 TableAdapter 時 (設定 [資料集專案] 屬性),將不會自動移動專案中的現有部份資料集類別。現有資料集部分類別必須手動移至資料集專案。 |
建立新的服務應用程式
因為這個逐步解說示範如何使用 WCF 服務來存取資料存取層,所以請建立新的 WCF 應用程式服務。
建立新的 WCF 應用程式服務
從 [檔案] 功能表中,將新的專案加入至 NTierWalkthrough 方案。
在 [新增專案] 對話方塊的 [專案類型] 中,按一下 [WCF]。 在 [範本] 窗格中,按一下 [WCF 服務程式庫]。
將專案命名為 DataService,然後按一下 [確定]。
隨即建立 DataService 專案,並將它加入至 NTierWalkthrough 方案。
在資料存取層中建立方法,以傳回 Customers 和 Orders 資料
資料服務必須在資料存取層中呼叫兩種方法:GetCustomers 和 GetOrders。 這些方法會傳回 Northwind Customers 和 Orders 資料表。 在 DataAccessTier 專案中,建立 GetCustomers 和 GetOrders 方法。
在資料存取層中建立可傳回 Customers 資料表的方法
在 [方案總管] 中,按兩下 [NorthwindDataset.xsd],以在 建立和編輯具類型資料集中開啟資料集。
在 CustomersTableAdapter 上按一下滑鼠右鍵,並按一下 [加入查詢] 開啟 TableAdapter 查詢組態精靈。
在 [選擇命令類型] 頁面上,保留 [使用 SQL 陳述式] 的預設值,再按 [下一步]。
在 [選擇查詢類型] 頁面上,保留 [傳回資料列的 SELECT] 的預設值,再按 [下一步]。
在 [指定 SQL SELECT 陳述式] 頁面上,保留預設查詢,再按 [下一步]。
在 [選擇要產生的方法] 頁面上,於 [傳回 DataTable] 區段的 [方法名稱] 中輸入 GetCustomers。
按一下 [完成]。
在資料存取層中建立可傳回 Orders 資料表的方法
在 OrdersTableAdapter 上按一下滑鼠右鍵,並按一下 [加入查詢]。
在 [選擇命令類型] 頁面上,保留 [使用 SQL 陳述式] 的預設值,再按 [下一步]。
在 [選擇查詢類型] 頁面上,保留 [傳回資料列的 SELECT] 的預設值,再按 [下一步]。
在 [指定 SQL SELECT 陳述式] 頁面上,保留預設查詢,再按 [下一步]。
在 [選擇要產生的方法] 頁面上,於 [傳回 DataTable] 區段的 [方法名稱] 中輸入 GetOrders。
按一下 [完成]。
在 [建置] 功能表上,按一下 [建置方案]。
將資料實體和資料存取層的參考加入至資料服務
因為資料服務需要來自資料集和 TableAdapter 的資訊,所以請加入 DataEntityTier 和 DataAccessTier 專案的參考。
加入資料服務的參考
在 [方案總管] 中,於 DataService 上按一下滑鼠右鍵,然後按一下 [加入參考]。
在 [加入參考] 對話方塊中,按一下 [專案] 索引標籤。
選取 [DataAccessTier] 和 [DataEntityTier] 專案。
按一下 [確定]。
將函式加入至服務,以在資料存取層中呼叫 GetCustomers 和 GetOrders 方法
現在,資料存取層包含方法可以傳回資料、在資料服務中建立方法以呼叫資料存取層中的方法。
注意事項 |
---|
針對 C# 專案,您必須加入下列程式碼的 System.Data.DataSetExtensions 組件參考以進行編譯。 |
在資料服務中建立 GetCustomers 和 GetOrders 函式
在 [DataService] 專案中,連按兩下 IService1.vb 或 IService1.cs。
在 [在此加入您的服務作業] 註解下,加入下列程式碼:
<OperationContract()> _ Function GetCustomers() As DataEntityTier.NorthwindDataSet.CustomersDataTable <OperationContract()> _ Function GetOrders() As DataEntityTier.NorthwindDataSet.OrdersDataTable
[OperationContract] DataEntityTier.NorthwindDataSet.CustomersDataTable GetCustomers(); [OperationContract] DataEntityTier.NorthwindDataSet.OrdersDataTable GetOrders();
在 DataService 專案中,連按兩下 Service1.vb (或 Service1.cs)。
將下列程式碼加入至 Service1 類別中:
Public Function GetCustomers() As DataEntityTier.NorthwindDataSet.CustomersDataTable Implements IService1.GetCustomers Dim CustomersTableAdapter1 As New DataAccessTier.NorthwindDataSetTableAdapters.CustomersTableAdapter Return CustomersTableAdapter1.GetCustomers() End Function Public Function GetOrders() As DataEntityTier.NorthwindDataSet.OrdersDataTable Implements IService1.GetOrders Dim OrdersTableAdapter1 As New DataAccessTier.NorthwindDataSetTableAdapters.OrdersTableAdapter Return OrdersTableAdapter1.GetOrders() End Function
public DataEntityTier.NorthwindDataSet.CustomersDataTable GetCustomers() { DataAccessTier.NorthwindDataSetTableAdapters.CustomersTableAdapter CustomersTableAdapter1 = new DataAccessTier.NorthwindDataSetTableAdapters.CustomersTableAdapter(); return CustomersTableAdapter1.GetCustomers(); } public DataEntityTier.NorthwindDataSet.OrdersDataTable GetOrders() { DataAccessTier.NorthwindDataSetTableAdapters.OrdersTableAdapter OrdersTableAdapter1 = new DataAccessTier.NorthwindDataSetTableAdapters.OrdersTableAdapter(); return OrdersTableAdapter1.GetOrders(); }
在 [建置] 功能表上,按一下 [建置方案]。
建立呈現層以顯示來自資料服務的資料
現在,方案會包含有方法可以呼叫到資料存取層的資料服務、建立另一個將呼叫到資料服務的專案,並向使用者呈現資料。 在這個逐步解說中,建立 Windows Form 應用程式;這是多層式架構應用程式的呈現層。
建立呈現層專案
從 [檔案] 功能表中,將新的專案加入至 NTierWalkthrough 方案。
在 [新增專案] 對話方塊的 [專案類型] 中,按一下 [Windows]。 在 [範本] 窗格中,按一下 [Windows Form 應用程式]。
將專案命名為 PresentationTier,然後按一下 [確定]。
隨即建立 PresentationTier 專案,並將它加入至 NTierWalkthrough 方案。
將 PresentationTier 專案設定為啟始專案
因為呈現層是用來呈現資料並與之互動的實際用戶端應用程式,所以您必須將 PresentationTier 專案設定為啟始專案。
將新的呈現層專案設定為啟始專案
- 在 [方案總管] 中,於 [PresentationTier] 上按一下滑鼠右鍵,然後按一下 [設定為啟始專案]。
加入呈現層的參考
用戶端應用程式 PresentationTier 需要有資料服務的服務參考,才能存取服務中的方法。 此外,還需要有資料集參考,才能透過 WCF 服務啟用類型共用。 除非您透過資料服務啟用類型共用,否則呈現層將無法使用加入至部分資料集類別的程式碼。 因為您通常會將驗證這類程式碼加入至變更資料表事件的資料列和資料行,所以可能會想要從用戶端存取此程式碼。
加入呈現層的參考
在 [方案總管] 中,於 PresentationTier 上按一下滑鼠右鍵,然後按一下 [加入參考]。
在 [加入參考] 對話方塊中,按一下 [專案] 索引標籤。
選取 [DataEntityTier],然後按一下 [確定]。
加入呈現層的服務參考
在 [方案總管] 中,於 PresentationTier 上按一下滑鼠右鍵,然後按一下 [加入服務參考]。
在 [加入服務參考] 對話方塊中,按一下 [探索]。
選取 [Service1],然後按一下 [確定]。
注意事項 如果您在目前電腦上有多個服務,則請選取先前在這個逐步解說中建立的服務 (含有 GetCustomers 和 GetOrders 方法的服務)。
將 DataGridViews 加入至表單以顯示資料服務所傳回的資料
在您加入資料服務的服務參考之後,會將服務所傳回的資料自動填入 [資料來源] 視窗。
將兩個繫結 DataGridViews 的資料加入至表單
在 [方案總管] 中,選取 PresentationTier 專案。
在 [資料來源] 視窗中,展開 [NorthwindDataSet],並找到 [Customers] 節點。
將 [Customers] 節點拖曳至 Form1。
在 [資料來源] 視窗中,展開 [Customers] 節點,並找到相關 [Orders] 節點 (巢狀於 [Customers] 節點中的 [Orders] 節點)。
將相關 [Orders] 節點拖曳至 Form1。
按兩下表單的空白區域,以建立 Form1_Load 事件處理常式。
將下列程式碼加入至 Form1_Load 事件處理常式。
Dim DataSvc As New ServiceReference1.Service1Client NorthwindDataSet.Customers.Merge(DataSvc.GetCustomers) NorthwindDataSet.Orders.Merge(DataSvc.GetOrders)
ServiceReference1.Service1Client DataSvc = new ServiceReference1.Service1Client(); northwindDataSet.Customers.Merge(DataSvc.GetCustomers()); northwindDataSet.Orders.Merge(DataSvc.GetOrders());
增加服務允許的訊息大小上限
因為服務會傳回來自 Customers 和 Orders 資料表的資料,所以 maxReceivedMessageSize 的預設值不足以保留資料,因此必須予以增加。 在這個逐步解說中,您會將此值變更為 6553600。 您將在用戶端上變更此值,而這樣會自動更新服務參考。
注意事項 |
---|
較小的預設大小是要限制拒絕服務 (DoS) 攻擊的機率。如需詳細資訊,請參閱MaxReceivedMessageSize。 |
增加 maxReceivedMessageSize 值
在 [方案總管] 中,按兩下 PresentationTier 專案中的 app.config 檔案。
找到 [maxReceivedMessage] 大小屬性,並將值變更為 6553600。
測試應用程式
執行應用程式。 資料是擷取自資料服務,並顯示在表單上。
若要測試應用程式
按 F5。
Customers 和 Orders 資料表中的資料是擷取自資料服務,並顯示在表單上。
後續步驟
根據應用程式需求,當您在 Windows 應用程式中儲存相關資料之後,可能會有幾個想要執行的步驟。 例如,您可以對此應用程式進行下列增強:
將驗證加入至資料集。 如需詳細資訊,請參閱 逐步解說:將驗證加入至 N-Tier 資料應用程式。
將其他方法加入至服務,以將資料更新回資料庫。