请问mongodb为什么比mysql效率高,求详细,
4个回答
展开全部
首先是内存映射机制,数据不是持久化到存储设备中的,而是暂时存储在内存中,这就提高了在IO上效率以及操作系统对存储介质之间的性能损耗。(毕竟内存读取最快)
其次,NoSQL并不是不使用sql,只是不使用关系。没有关系的存在,就表示每个数据都好比是拥有一个单独的存储空间,然后一个聚集索引来指向。搜索性能一定会提高的。
第三,语言。使用javascript语法进行操作更加高效、直接。
这些是MongoDB针对关系型数据库的效率要高的原因。但是不能仅仅看重效率,这种数据库的设计带来的弊端也是有的。例如数据关系的维护会带来很多冗余数据、客户端代码需要大量针对数据库进行的IO操作、数据挖掘难以实现等等。
所以,应当针对应用系统来选择合适的数据存储介质才是优先需要考虑的。
其次,NoSQL并不是不使用sql,只是不使用关系。没有关系的存在,就表示每个数据都好比是拥有一个单独的存储空间,然后一个聚集索引来指向。搜索性能一定会提高的。
第三,语言。使用javascript语法进行操作更加高效、直接。
这些是MongoDB针对关系型数据库的效率要高的原因。但是不能仅仅看重效率,这种数据库的设计带来的弊端也是有的。例如数据关系的维护会带来很多冗余数据、客户端代码需要大量针对数据库进行的IO操作、数据挖掘难以实现等等。
所以,应当针对应用系统来选择合适的数据存储介质才是优先需要考虑的。
追问
mongo数据是存放内存中的吗?那不是关机后就会丢失?还有怎么说mongo是用javascript进行操作的呢,那mysql用什么语法的呢?
追答
mysql用什么语法我不知道,类似sql92规范下的自己开发的版本吧。mongo底层的语法使用javascript进行对shell的解析,也就是说你使用的javascript语言进行对mongodb数据库的操作。
mongo的数据存放在内存,这是用于快速存取数据用的。mongo有自己的同/异步机制(SafeMode),可以选择数据暂时存放在内存中,还是存放在文件系统中。
展开全部
简单的说,没有join,没有事务,使用内存映射,因此效率高。
上面的哥们,mongo服务器实现是C++,跟javascript没有半毛钱关系啊。
你说的javascript指的是客户端,客户端支持很多种语言,跟服务器是否快没有关系的。
上面的哥们,mongo服务器实现是C++,跟javascript没有半毛钱关系啊。
你说的javascript指的是客户端,客户端支持很多种语言,跟服务器是否快没有关系的。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
mongodb 会比mysql快的多,原因是:
首先是内存映射机制,数据不是持久化到存储设备中的,而是暂时存储在内存中,这就提高了在IO上效率以及操作系统对存储介质之间的性能损耗。(毕竟内存读取最快)
其次,NoSQL并不是不使用sql,只是不使用关系。没有关系的存在,就表示每个数据都好比是拥有一个单独的存储空间,然后一个聚集索引来指向。搜索性能一定会提高的。
第三,语言。使用javascript语法进行操作更加高效、直接。
这些是MongoDB针对关系型数据库的效率要高的原因。但是不能仅仅看重效率,这种数据库的设计带来的弊端也是有的。例如数据关系的维护会带来很多冗余数据、客户端代码需要大量针对数据库进行的IO操作、数据挖掘难以实现等等。
首先是内存映射机制,数据不是持久化到存储设备中的,而是暂时存储在内存中,这就提高了在IO上效率以及操作系统对存储介质之间的性能损耗。(毕竟内存读取最快)
其次,NoSQL并不是不使用sql,只是不使用关系。没有关系的存在,就表示每个数据都好比是拥有一个单独的存储空间,然后一个聚集索引来指向。搜索性能一定会提高的。
第三,语言。使用javascript语法进行操作更加高效、直接。
这些是MongoDB针对关系型数据库的效率要高的原因。但是不能仅仅看重效率,这种数据库的设计带来的弊端也是有的。例如数据关系的维护会带来很多冗余数据、客户端代码需要大量针对数据库进行的IO操作、数据挖掘难以实现等等。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
引用sniper2003的回答:
首先是内存映射机制,数据不是持久化到存储设备中的,而是暂时存储在内存中,这就提高了在IO上效率以及操作系统对存储介质之间的性能损耗。(毕竟内存读取最快)
其次,NoSQL并不是不使用sql,只是不使用关系。没有关系的存在,就表示每个数据都好比是拥有一个单独的存储空间,然后一个聚集索引来指向。搜索性能一定会提高的。
第三,语言。使用javascript语法进行操作更加高效、直接。
这些是MongoDB针对关系型数据库的效率要高的原因。但是不能仅仅看重效率,这种数据库的设计带来的弊端也是有的。例如数据关系的维护会带来很多冗余数据、客户端代码需要大量针对数据库进行的IO操作、数据挖掘难以实现等等。
所以,应当针对应用系统来选择合适的数据存储介质才是优先需要考虑的。
首先是内存映射机制,数据不是持久化到存储设备中的,而是暂时存储在内存中,这就提高了在IO上效率以及操作系统对存储介质之间的性能损耗。(毕竟内存读取最快)
其次,NoSQL并不是不使用sql,只是不使用关系。没有关系的存在,就表示每个数据都好比是拥有一个单独的存储空间,然后一个聚集索引来指向。搜索性能一定会提高的。
第三,语言。使用javascript语法进行操作更加高效、直接。
这些是MongoDB针对关系型数据库的效率要高的原因。但是不能仅仅看重效率,这种数据库的设计带来的弊端也是有的。例如数据关系的维护会带来很多冗余数据、客户端代码需要大量针对数据库进行的IO操作、数据挖掘难以实现等等。
所以,应当针对应用系统来选择合适的数据存储介质才是优先需要考虑的。
展开全部
mongo的数据确实是首先存储在内存里,但最终还是要写到硬盘中去的,只不过这个写操作是异步的。
比如往mongo数据库写操作,返回的结果是写入成功,其实此时只是写入内存成功,并不是写入硬盘成功,有专门的机制异步处理把内存中的数据持久化到硬盘中去的,只不过会稍微有点延时。
比如往mongo数据库写操作,返回的结果是写入成功,其实此时只是写入内存成功,并不是写入硬盘成功,有专门的机制异步处理把内存中的数据持久化到硬盘中去的,只不过会稍微有点延时。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询