树状控件中数据量太大应怎样处理呢?

supercoolxyz 2005-10-12 10:13:11
每次对树状控件的刷新都要从数据库中读取大量的数据,这样导致树状控件要等好一会才能完全显示出来,有时还会出现整个程序无法响应并出错.请问应该用怎样的方法来处理这样一个过程呢?(既从数据库读取大量的数据来导入树状控件有什么好的方法吗?)
...全文
1017 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
mymyal123 2005-10-12
  • 打赏
  • 举报
回复
那就是异步加载树

zxyjyzxyjy 2005-10-12
  • 打赏
  • 举报
回复
如果这样,那就每次读取需要的那一层树的数据,在树扩展时再读取其下一层的数据。如果还慢的话,那数据库表进行优化设计。
supercoolxyz 2005-10-12
  • 打赏
  • 举报
回复
没得优化的.数据库中的所有数据都要导入到树状控件.
用线程插入数据也要等到数据全部导完才能进行操作呀.虽然程序不会停止响应.
duyhui 2005-10-12
  • 打赏
  • 举报
回复
首先数据库查询要优化优化,建索引什么的
其次,插入树的操作应该放在线程里插入,这样程序不会停止响应.

supercoolxyz 2005-10-12
  • 打赏
  • 举报
回复
就是因为数据库中的内容改变了才导致树状控件的显示需要改变的.先把数据库的数据读到数组中再在树状控件中显示出来,不知道效果会不会好些呢?树状控件中一层一层下来,总的子节点好多的.
zxyjyzxyjy 2005-10-12
  • 打赏
  • 举报
回复
如果树控件的数据不变,则封装成一个树控件的派生类,在这个类中读全部数据和建树,以后拿来用就行,还可以把数据设为静态,以后建该类时就不用从数据库中读数据了。至于刷新问题,在打开节点时如有子节点那一定是要刷新的了。
teli_eurydice 2005-10-12
  • 打赏
  • 举报
回复
LockWindowUpdate();
UnlockWindowUpdate();
supercoolxyz 2005-10-12
  • 打赏
  • 举报
回复
上面的方法行不通呀..
DentistryDoctor 2005-10-12
  • 打赏
  • 举报
回复
m_treeCtrl.SetRedraw(FALSE);
...
m_treeCtrl.SetRedraw(TRUE);
带选择框的JS树控件 页面创建一个HTMLElement是很耗时的,无论使用createElement或者是是innerHTML都一样。 而且这一步只能一个节点一个节点慢慢地生成,虽然可以通过减小单个节点的HTML元素量的方法提高一些速度,但是对于对于上千个节点来说仍然需要等上几十秒。 (1个节点如果有5个HTMLElement,生成1000个节点大概3秒左右) 所以只有通过异步展示的方法来进一步减少一次生成的节点数。 页面加载时并不立即生成所有节点的HTML元素,而是用户展开多少节点就生成多少节点,节点的生成发生在用户展开这个节点的时候。 这样减少了每次生成的节点数,消除了使用者的等待时间。 而对于节点的检索,这和数据的组织方式有关。 一般的组织方式是使用数组。(解析XML的话太慢,不考虑。只考虑使用json的情况) 但是在数组检索一个节点的效率实在不敢恭维,如果节点是N个,那么全部节点数据组装起来的效率就是N*N 在节点少的时候不明显,但是如果有1000个节点,那么明显会发觉延迟了10多秒。延迟速度按指数增加。 MzTree(梅花雪)使用了另外一种方式,他没有使用数组而是使用一个简单对象来存放数组。 并且用一个字符串存放节点的索引关系(将所有的节点名(即类的属性名)join()成一个大字符串) 当需要获得子节点的时候使用正则匹配一步获得子节点ID,从而获得子节点。 经过测试发现,使用正则匹配的算法检索节点效率比使用for循环要高出很多。 这个效率已经满足一般大数据jstree的需要。 (具体算法,去参考MzTree梅花雪)

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧