日期:2012-12-27  浏览次数:20406 次

第 4 章 数据库基础2:  添加自定义数据 在这一章中,我们将创建一个新的字典对象,它用来表示我们雇员就职的 ‘Acme 公司‘(呵呵,当然是虚构的一家公司)的部门。这个“部门”字典对象将包含一个表示部门经理的记录。我们还会加入代码到雇员创建过程,这个过程会加入一个索引到雇员工作的部门。我们要说明的是如何在DWG文件中创建自定义数据,包括“每个图形”的自定义数据和“每个实体”的自定义数据。“每个图形”的自定义数据是指只在整个图形中加入一次的数据,它表示对象可以引用的单一类型或特性。“每个实体”的自定义数据是指是为特定的对象或数据库中的实体加入的数据。在下面的示例中,我们将加入“每个图形”的自定义数据到命名对象字典(简称NOD)。NOD存在于每一个DWG文件中。“每个实体”的自定义数据加入到一个名为“扩展字典”的字典(可选)中,它表示每一个雇员。每一个由DBObject派生的对象都拥有存储自定义数据的扩展字典。而在我们的示例中将包含这种自定义数据如名字、薪水和部门。因此这一章的重点是字典对象和扩展记录(XRecord),它们是我们用来表示自定义数据的容器。首先让我们来创建表示公司的条目。在本章的前几个步骤中,我们将创建如下所示的部门层次结构:  NOD-命名对象字典     ACME_DIVISION-自定义公司字典               销售(Sales) -部门字典                       部门经理-部门条目 请打开Lab4文件夹下的Lab4工程,或接着Lab3的代码。<!--[if !supportLists]-->1)                   <!--[endif]-->我们首先要做的是定义一个新的函数,它用来在命名对象字典(NOD)中创建公司字典对象。为这个函数取名为CreateDivision(),,并使用命令属性来定义CREATEDIVISION命令。下面是这个函数的代码,它的形式非常简单,只是用来在NOD中创建一个ACME_DIVISION(用来表示公司)    <CommandMethod("CREATEDIVISION")> _        Public Function CreateDivision()        Dim db = HostApplicationServices.WorkingDatabase        Dim trans As Transaction = db.TransactionManager.StartTransaction()        Try            '首先,获取NOD……            Dim NOD As DBDictionary = trans.GetObject(db.NamedObjectsDictionaryId, OpenMode.ForWrite, False)            '定义一个公司级别的字典            Dim acmeDict As DBDictionary            Try                '如果ACME_DIVISION不存在,则转到catch块,这里什么也不做                acmeDict = trans.GetObject(NOD.GetAt("ACME_DIVISION"), OpenMode.ForRead)            Catch                '如果ACME_DIVISION不存在,则创建它并把它加入到NOD中……                acmeDict = New DBDictionary()                NOD.SetAt("ACME_DIVISION", acmeDict)                trans.AddNewlyCreatedDBObject(acmeDict, True)            End Try            trans.Commit()        Finally            trans.Dispose()        End Try    End Function 请仔细阅读一下上面的代码块的结构,可以通过注释来了解相关的细节。特别要注意的是我们是如何用一个try-catch块来处理ACME_DIVISION是否存在?如果ACME_DIVISION字典不存在,GetObject()将会抛出异常,catch块被执行,它会创建一个新的字典。运行这个函数来看它是否可行。可以使用数据库查看工具来检查字典是否已被加入(建议使用ARX SDK的ArxDbg工具)<!--[if !supportLists]-->2)                   <!--[endif]-->接下来,我们要在ACME_DIVISION字典中加入销售(Sales)条目。销售(Sales)条目同样也是一个字典。由于销售(Sales)与ACME_DIVISION字典的关系如同ACME_DIVISION字典与NOD,所以代码是类似的。定义下面的代码部分在ACME_DIVISION字典中创建一个名为’Sales’的字典。代码提示:Code hint:                    Dim divDict As DBDictionary   &nbs