明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1315|回复: 4

[基础] 求教:希望实现递归打印数据字典内容,程序出错。还请高手指点一二。

[复制链接]
发表于 2011-4-23 18:32 | 显示全部楼层 |阅读模式
public class testNod
    {
        Database db = HostApplicationServices.WorkingDatabase;
        Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
        [CommandMethod("tess")]        
        public void Test()
        {
            using (Transaction trans = db.TransactionManager.StartTransaction())
            {
                ObjectId nodId = db.NamedObjectsDictionaryId;
                nodeSearch(nodId);
                trans.Commit();
            }
        }
        private void nodeSearch(ObjectId nodId)
        {
            Transaction trans = db.TransactionManager.StartTransaction();
            DBDictionary nod = (DBDictionary)trans.GetObject(nodId, OpenMode.ForWrite);
            DbDictionaryEnumerator dictEnum = nod.GetEnumerator();
            ObjectId objId = new ObjectId();
            
            while (dictEnum.MoveNext())
            {
                objId = dictEnum.Value;
                string objName = dictEnum.Key;
                ed.WriteMessage("\n" + objId.ToString() + "   " + objName);
                if (trans.GetObject(nodId, OpenMode.ForWrite) is DBDictionary)
                {
                    nodeSearch(objId);
                }
                else
                {
                    break;
                }
            }
        }
    }
 楼主| 发表于 2011-4-24 00:46 | 显示全部楼层
本帖最后由 jdjb 于 2011-4-24 00:51 编辑

我调试好的代码。 还有两点不明请大家指教。
1.未调用trans.commit为何不发生错误,什么时候需要调用commit什么时候不需要。
2.是否有高手为小弟对trans实现机制稍作指点。
public class testNod
    {
        Database db = HostApplicationServices.WorkingDatabase;
        Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
        [CommandMethod("tess")]        
        public void Test()
        {

                ObjectId nodId = db.NamedObjectsDictionaryId;
                nodeSearch(nodId);

        }
        private void nodeSearch(ObjectId nodId)
        {
            using (Transaction trans = db.TransactionManager.StartTransaction())
            {
                DBDictionary nod = trans.GetObject(nodId, OpenMode.ForWrite) as DBDictionary;
                if (nod != null)
                {
                    DbDictionaryEnumerator dictEnum = nod.GetEnumerator();
                    ObjectId objId = new ObjectId();
                    while (dictEnum.MoveNext())
                    {
                        objId = dictEnum.Value;
                        string objName = dictEnum.Key;
                        ed.WriteMessage("\n" + objId.ToString() + "   " + objName);
                        nodeSearch(objId);
                    }
                }
            }

        }
    }
发表于 2011-4-24 09:02 | 显示全部楼层
本帖最后由 sieben 于 2011-4-24 09:13 编辑

1,数据词典DBDictionary里面的可能是词典DBDictionary,也可能是扩展记录Xrecord
2,我也不大明白"什么时候需要调用commit什么时候不需要",我简单理解为只读不需要,写入则需要
(后注:这里回的是二楼)

发表于 2011-4-24 09:07 | 显示全部楼层
本帖最后由 sieben 于 2011-4-24 09:14 编辑

  private void nodeSearch(ObjectId nodId)
        {
            DBDictionary nod = (DBDictionary)trans.GetObject(nodId, OpenMode.ForWrite);
                if (trans.GetObject(nodId, OpenMode.ForWrite) is DBDictionary)
                {
                    nodeSearch(objId);
                }
-------------------------------
1,这里怀疑变量写错了,if (trans.GetObject(nodId, OpenMode.ForWrite) is DBDictionary) 实是想写if (trans.GetObject(objId, OpenMode.ForWrite) is DBDictionary)
2,不管是objId 还是 nodId,你都重复打开了
(后注:这里回的是一楼,回二楼时没有看到一楼)

发表于 2011-4-24 16:49 | 显示全部楼层
本帖最后由 chmenf087 于 2011-4-24 16:51 编辑

.commit() 和.abort两个是对应的commit表示事务所有在commit之前的操作都被存储,而.abort则表示回滚,放弃前面所有对数据库的操作,因此没有需要在数据库中存储的操作时就不需要.commit()
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-5-17 11:46 , Processed in 0.227149 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表