分享更有价值
被信任是一种快乐

MySQL与MongoDB的操作命令对比以及区别是怎样的

文章页正文上

本篇文章为大家展示了MySQL与MongoDB的操作命令对比以及区别是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。  MySQL与Mong免费主机域名oDB都是开源的常用数据库,但是MySQL是传统的关系型数据库,MongoDB则是非关系型数据库,也叫文档型数据库,是一种NoSQL的数据库。它们各有各的优点,关键是看用在什么地方。所以我们所熟知的那些SQL(全称Structured Query Language)语句就不适用于MongoDB了,因为SQL语句是关系型数据库的标准语言。  以我们公司项目为例,在早期的项目中,都在使用关系型数据库,用过SQLServer,Oracle,DB2,后来全部转向Mysql,原因很简单:Mysql在性能不错的情况下,有着开源优势。Mysql的事务性与高性能是我们主要考虑的。后来,由于项目要用到用户系统,即会有大量的用户数据进行交互–海量存储,Mysql的读写速度会有一点瓶颈,于是我们就想到了最近发展很强势的Nosql。在Nosql早期的memcache的发展下,又出现了很多非关系型数据库,比如redis,mongodb。经过一段时间的测试,redis与mongodb的读写速度确实比Mysql有着很明显的优势。mongodb的写入速度大约2.5W/次每秒。 mongodb以BSON结构(二进制)进行存储,对海量数据存储有着很明显的优势。  下面是Mongodb与Mysql的操作命令的对比。  服务器守护进程mysqld/mongod;  客户端工具mysql/mongo;  逻辑备份工具mysqldump/mongodump;  逻辑还原工具mysql/m免费主机域名ongorestore;  数据导出工具mysqldump/mongoexport;  数据导入工具source/mongoimport;  新建用户并授权grant all on *.* to username@’localhost’ identified by ‘passwd’;db.addUser(“user”,”psw”) db.auth(“user”,”psw”);  显示库列表show databases;show dbs;  进去库use dbname;use dbname;  显示表列表show tables;show collections;  查询主从状态show slave status;rs.status;  创建库create database name;无需单独创建,直接use进去;  创建表create table tname(id int);无需单独创建,直接插入数据;  删除表drop table tname;db.tname.drop();  删除库drop database dbname;首先进去该库,db.dropDatabase();  插入记录insert into tname(id) value(2);db.tname.insert({id:2});  删除记录delete from tname where id=2;db.tname.remove({id:2});  修改/更新记录update tname set id=3 where id=2;db.tname.update({id:2},{$set:{id:3}},false,true);  查询所有记录select * from tname;db.tname.find();  查询所有列select id from tname;db.tname.find({},{id:1});  条件查询select * from tname where id=2;db.tname.find({id:2});  条件查询select * from tname where id =2;db.tname.find({id:{$gte:2}});  条件查询select * from tname where id=2 and name=’steve’;db.tname.find({id:2,name:’steve’});  条件查询select * from tname where id=2 or name=’steve’;db.tname.find($or:[{id:2},{name:’steve’}]);  条件查询select * from tname limit 1;db.tname.findOne();  模糊查询select * from tname where name like “%ste%”;db.tname.find({name:/ste/});  模糊查询select * from tname where name like “ste%”;db.tname.find({name:/^ste/});  获取表记录数select count(id) from tname;db.tname.count();  获取有条件的记录数select count(id) from tnamewhere id=2;db.tname.find({id:2}).count();  查询时去掉重复值select distinct(last_name) from tname;db.tname.distinct(‘last_name’);  正排序查询select *from tname order by id;db.tname.find().sort({id:1});  逆排序查询select *from tname order by id desc;db.tname.find().sort({id:-1});  取存储路径explain select * from tname  where id=3;db.tname.find({id=3}).explain();  特别要注意的是:mongodb插入多个字段语法。  > db.user.insert({id:1,name:’steve’,sex:’male’}) 正确。  > db.user.insert({id:2},{name:’bear’},{sex:’female’}) 错误。上述内容就是MySQL与MongoDB的操作命令对比以及区别是怎样的,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注云技术行业资讯频道。

相关推荐: 怎么解决sql2000挂起无法安装的问题

这篇文章主要介绍“怎么解决sql2000挂起无法安装的问题”,在日常操作中,相信很多人在怎么解决sql2000挂起无法安免费主机域名装的问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么解决sql2000挂起无法安装的问题”…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册