程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> 關於C# >> C#自定義數據詳解

C#自定義數據詳解

編輯:關於C#

C#語言有很多值得學習的地方,這裡我們主要介紹C#自定義數據,包括介紹每一個由 DBObject派生的對象都擁有存儲C#自定義數據的擴展字典等方面。

我們將創建一個新的字典對象,它用來表示我們雇員就職的 ‘Acme 公司‘( 呵呵,當然是虛構的一家公司)的部門。這個“部門”字典對象將包含一個表示 部門經理的記錄。我們還會加入代碼到雇員創建過程,這個過程會加入一個索引到雇員工作 的部門。

我們要說明的是如何在DWG文件中創建C#自定義數據,包括“每個圖形”的C# 自定義數據和“每個實體”的C#自定義數據。“每個圖形”的C#自定 義數據是指只在整個圖形中加入一次的數據,它表示對象可以引用的單一類型或特性。 “每個實體”的C#自定義數據是指是為特定的對象或數據庫中的實體加入的數據 。

在下面的示例中,我們將加入“每個圖形”的C#自定義數據到命名對象字典( 簡稱NOD)。NOD存在於每一個DWG文件中。“每個實體”的C#自定義數據加入到一 個名為“擴展字典”的字典(可選)中,它表示每一個雇員。每一個由DBObject 派生的對象都擁有存儲C#自定義數據的擴展字典。而在我們的示例中將包含這種C#自定義數 據如名字、薪水和部門。

因此這一章的重點是字典對象和擴展記錄(XRecord),它們是我們用來表示C#自定義數 據的容器。

首先讓我們來創建表示公司的條目。在本章的前幾個步驟中,我們將創建如下所示的部門 層次結構:

◆NOD-命名對象字典

◆ACME_DIVISION-自定義公司字典

◆銷售(Sales) -部門字典

◆部門經理-部門條目

請打開Lab4文件夾下的Lab4工程,或接著Lab3的代碼。

< !--[if !supportLists]-->1) < !--[endif]-->我們首先要做的是定義一 個新的函數,它用來在命名對象字典(NOD)中創建公司字典對象。為這個函數取名為 CreateDivision(),,並使用命令屬性來定義CREATEDIVISION命令。

下面是這個函數的代碼,它的形式非常簡單,只是用來在NOD中創建一個ACME_DIVISION( 用來表示公司)

[CommandMethod("CreateDivision")]
public void CreateDivision()
{
Database db = HostApplicationServices.WorkingDatabase;
Transaction trans = db.TransactionManager.StartTransaction();
try
{
//首先,獲取NOD……
DBDictionary NOD = (DBDictionary)trans.GetObject
(db.NamedObjectsDictionaryId, OpenMode.ForWrite);
//定義一個公司級別的字典
DBDictionary acmeDict;
try
{
//如果ACME_DIVISION不存在,則轉到catch塊,這裡什麼也不做
acmeDict = (DBDictionary)trans.GetObject(NOD.GetAt("ACME_DIVISION"),  OpenMode.ForRead);
}
catch
{
//如果ACME_DIVISION不存在,則創建它並把它加入到NOD中……
acmeDict = new DBDictionary();
NOD.SetAt("ACME_DIVISION", acmeDict);
trans.AddNewlyCreatedDBObject(acmeDict, true);
}
trans.Commit();
}
finally
{
trans.Dispose();
}
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved