首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

mongodb与mysql区别对比

举例来说,在传统的关系型数据库中,一个COUNT类型的操作会锁定数据集,这样可以保证得到“当前”情况下的较精确值。这在某些情况下,例 如通过ATM查看账户信息的时候很重要,但对于Wordnik来说,数据是不断更新和增长的,这种“较精确”的保证几乎没有任何意义,反而会产生很大的延 迟。他们需要的是一个“大约”的数字以及更快的处理速度。 但某些情况下MongoDB会锁住数据库。如果此时正有数百个请求,则它们会堆积起来,造成许多问题。我们使用了下面的优化方式来避免锁定: 每次更新前,我们会先查询记录。查询操作会将对象放入内存,于是更新则会尽可能的迅速。在主/从部署方案中,从节点可以使用“-pretouch”参数运行,这也可以得到相同的效果。

01

mysql删除数据空间没有释放

OPTIMIZE TABLE 当您的库中删除了大量的数据后,您可能会发现数据文件尺寸并没有减小。这是因为删除操作后在数据文件中留下碎片所致。OPTIMIZE TABLE 是指对表进行优化。如果已经删除了表的一大部分数据,或者如果已经对含有可变长度行的表(含有 VARCHAR 、 BLOB 或 TEXT 列的表)进行了很多更改,就应该使用 OPTIMIZE TABLE 命令来进行表优化。这个命令可以将表中的空间碎片进行合并,并且可以消除由于删除或者更新造成的空间浪费 。OPTIMIZE TABLE 命令只对 MyISAM 、 BDB 和 InnoDB 表起作用 。表优化的工作可以每周或者每月定期执行,对提高表的访问效率有一定的好处,但是需要注意的是,优化表期间会锁定表,所以一定要安排在空闲时段进行。

02

《数据库索引设计优化》读书笔记(六)

第10章 多索引访问 练习 10.1 假设多索引访问一节中所描述的拥有位图索引的CIA表包含200000000行数据。请评估(a)位图索引和(b)半宽B树索引所需的磁盘空间。 假设一个字节占8位。请将磁盘空间的差异转化为每月需要支付的美元金额。 书中关于拥有位图索引的CIA表的描述如下:    位图索引的比较优势在于能够很容易地使用多个位图索引来满足单个查询。考虑一个有多个谓词条件的查询,每个谓词上都有一个索引。虽然有些系统可能尝试对多个索引的记录标识进行交集操作,但是传统的数据库可能会只使用其中一个索引。位图索引在此种情况下工作得更好,因为它们更紧凑,而且计算几个位图的交集比计算几个记录集合的交集更快。在最好的情况下,性能的提升与机器的字长成比例,因为同一时间两个位图能够进行一个字长的位的交集计算。最佳的使用场景是,每一个单独谓词的选择性不好,但是所有谓词一起进行索引与后的选择性很好。位图索引考虑如下查询,“找出有棕色头发,戴眼镜,年龄在30岁至40岁之间,蓝眼睛,从事计算机行业并居住在加利福利亚的人”。这意味着对棕色头发位图、佩戴眼镜的位图、年龄在30岁至40岁间的位图等进行交集计算。    在当前的磁盘条件下,只要查询中没有太多的范围谓词,使用一个半宽B树索引是性能最佳的方案,即便对于像CIA那样的应用来说也是如此。对于上文中的例子,一个用HAIRCOLOUR、 GLASSES、EYECOLOUR、INDUSTRY和STATE的任意排序序列作为开头,并以DATE OF BIRTH作为第6列的索引将提供非常出色的性能,因为这使得访问路径将会有6个匹配列:包含目标结果集的索引片将会非常窄。 分析: 位图索引的空间主要跟表的记录数和索引列的键值数有关,题目中只给了表的记录数,所以需要根据实际情况可以确定6个位图索引的键值数如下: 头发颜色 键值数为5 是否戴眼镜 键值数为2 年龄段 键值数为10 眼睛颜色 键值数为10 行业 键值数为100 州 键值数为50 (a)6个位图索引需要的磁盘空间为 (5+2+10+10+100+50) * 200000000 /8/1024/1024/1024 = 4.12G B树索引的空间跟索引字段的长度有关,假设半宽索引的6个字段的总长为50字节 (b)半宽B树索引所需的磁盘空间为 1.5 * 50 * 200000000 /1024/1024/1024 = 13.97G

02

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券