美文网首页
强强对比 MongoDB与MySQL

强强对比 MongoDB与MySQL

作者: 星月落 | 来源:发表于2019-08-16 10:30 被阅读0次

一、前言

MongoDB 虽说是文档型数据库,但是在学习和使用其语法时发现又与 MySQL 有些相似之处,在此记录点滴日后复习。

二、概念区别

比较MySQLMongoDB

库databasedatabase

表tablecollection

行rowdocument

列columnfield

索引indexindex

表关联table joins$lookup

主键primary keyprimary key

聚合aggregationaggregation pipeline

三、命令区别

比较MySQLMongoDB

服务端mysqldmongod

客户端mysqlmongo

四、关键字和函数区别

MySQLMongoDB

where$match

group by$group

having$match

select$project

order by$sort

limit$limit

sum()$sum

count()$sum

join$lookup

五、语句区别

# 5.1 表结构

# 5.1.1 创建表/集合

db.people.insertOne( {

user_id:"abc123",

age:55,

status:"A"

} )

相当于

CREATETABLEpeople(

idMEDIUMINTNOTNULLAUTO_INCREMENT,

user_idVarchar(30),

ageNumber,

statuschar(1),

PRIMARYKEY(id)

)

# 5.1.2 新增字段

db.people.updateMany(

{ },

{ $set: { join_date:newDate() } }

)

相当于 ALTER TABLE people ADD join_date DATETIME

# 5.1.3 删除字段

db.people.updateMany(

{ },

{ $unset: {"join_date":""} }

)

相当于 ALTER TABLE people DROP COLUMN join_date

# 5.1.4 创建索引

db.people.createIndex( {user_id:1} )

相当于CREATEINDEXidx_user_id_ascONpeople(user_id)

# 5.1.5 删除表/集合

db.people.drop()

相当于DROPTABLEpeople

# 5.2 新增记录/文档

db.people.insertOne(

{user_id:"bcd001", age:45, status:"A"}

)

相当于INSERTINTOpeople(user_id,age,status)VALUES("bcd001",45,"A")

# 5.3 查询记录/文档

# 5.3.1 简单查询

db.people.find()

相当于SELECT*FROMpeople

db.people.find(

{ },

{user_id:1, status:1}

)

相当于SELECTid,user_id,statusFROMpeople

db.people.find(

{ },

{user_id:1, status:1, _id:0}

)

相当于SELECTuser_id,statusFROMpeople

# 5.3.2 条件查询

db.people.find(

{ status:"A"}

)

相当于 SELECT * FROM people WHERE status ="A"

db.people.find(

{ status:"A"},

{ user_id:1, status:1, _id:0}

)

相当于 SELECT user_id, status FROM people WHERE status ="A"

# 5.3.3 非查询

db.people.find(

{ status: { $ne:"A"} }

)

相当于 SELECT * FROM people WHERE status !="A"

# 5.3.4 且查询

db.people.find(

{ status:"A",

age:50}

)

相当于 SELECT * FROM people WHERE status ="A"ANDage =50

# 5.3.5 或查询

db.people.find(

{ $or: [ { status:"A"} ,

{ age:50} ] }

)

相当于 SELECT * FROM people WHERE status ="A"ORage =50

# 5.3.6 大于查询

db.people.find(

{age: { $gt:25} }

)

相当于SELECT*FROMpeopleWHEREage> 25

# 5.3.7 小于查询

db.people.find(

{age: { $lt:25} }

)

相当于SELECT*FROMpeopleWHEREage< 25

# 5.3.8 范围查询

db.people.find(

{ age: { $gt:25, $lte:50} }

)

相当于 SELECT * FROM people WHERE age >25ANDage <=50

# 5.3.9 模糊查询

db.people.find( {user_id: /bc/ } ) 或db.people.find( {user_id: { $regex: /bc/ } } )

相当于SELECT*FROMpeopleWHEREuser_idlike"%bc%"

db.people.find( {user_id: /^bc/ } ) 或db.people.find( {user_id: { $regex: /^bc/ } } )

相当于SELECT*FROMpeopleWHEREuser_idlike"bc%"

# 5.3.10 排序查询

db.people.find( { status:"A"} ).sort( { user_id:1} )

相当于 SELECT * FROM people WHERE status ="A"ORDER BY user_id ASC

db.people.find( { status:"A"} ).sort( { user_id:-1} )

相当于 SELECT * FROM people WHERE status ="A"ORDER BY user_id DESC

# 5.3.11 统计查询

db.people.count() 或db.people.find().count()

相当于SELECTCOUNT(*)FROMpeople

db.people.count( {user_id: { $exists: true } } ) 或db.people.find( {user_id: { $exists: true } } ).count()

相当于SELECTCOUNT(user_id)FROMpeople

db.people.count( {age: { $gt:30} } ) 或db.people.find( {age: { $gt:30} } ).count()

相当于SELECTCOUNT(*)FROMpeopleWHEREage> 30

# 5.3.12 去重查询

db.people.distinct( "status" )

相当于SELECTDISTINCT(status)FROMpeople

# 5.3.13 分页查询

db.people.findOne() 或db.people.find().limit(1)

相当于SELECT*FROMpeopleLIMIT1

db.people.find().limit(5).skip(10)

相当于SELECT*FROMpeopleLIMIT5SKIP10

# 5.3.14 查询计划

db.people.find( { status:"A"} ).explain()

相当于 EXPLAIN SELECT * FROM people WHERE status ="A"

# 5.4 修改记录/文档

db.people.updateMany(

{ age: { $gt:25} },

{ $set: { status:"C"} }

);

相当于 UPDATE people SET status ="C"WHERE age >25;

db.people.updateMany(

{ status:"A"} ,

{ $inc: { age:3} }

);

相当于 UPDATE people SET age = age +3WHERE status ="A";

# 5.5 删除记录/文档

db.people.deleteMany( { status:"D"} );

相当于 DELETE FROM people WHERE status ="D";

db.people.deleteMany({});

相当于 DELETE FROM people;

六、参考资料

https://docs.mongodb.com/manual/reference/sql-aggregation-comparison/ 关键字和函数相关

https://docs.mongodb.com/manual/reference/sql-comparison/ 语句相关

源网络,版权归原创者所有。如有侵权烦请告知,我们会立即删除并表示歉意。谢谢。


更多技术,欢迎关注下方公众号

相关文章

  • 强强对比 MongoDB与MySQL

    一、前言 MongoDB 虽说是文档型数据库,但是在学习和使用其语法时发现又与 MySQL 有些相似之处,在此记录...

  • MongoDB 与 MySQL 对比

    MongoDB 与 MySQL 对比 由于公司系统使用MongoDB,虽然之前了解,但并没有深入学习MongoDB...

  • Mongodb 与 MySQL对比

    NoSQL 的全称是 Not Only SQL,也可以理解非关系型的数据库,是一种新型的革命式的数据库设计方式,不...

  • 2021-06-24【数据库】mgdb redis mysql

    全网最完整MongoDB 与 MySQL对比 (qq.com)[https://mp.weixin.qq.com/...

  • MongoDB与MySQL效率对比

    本文主要通过批量与非批量对比操作的方式介绍MongoDB的bulkWrite()方法的使用。顺带与关系型数据库My...

  • 《商君书》第四篇

    去强。 去强的意思就是消除百姓不服政令的弊端(弱民)。 一、国家强弱的几种对比。强民与刑罚,穷治与富治,兵敢与羞,...

  • mongodb的基本的命令行的操作-查询篇

    mongodb与mysql命令对比 传统的关系数据库是由:数据库(database)、表(table)、记录(re...

  • MongoDB语法与MySql语法对比

  • 君子之强,小人之强

    “南方之强与?北方之强与?抑与强与?” 我们对强的定义是什么呢?“强”,到底什么才能被称之为强?“强”,又意味...

  • mongoDB(一)

    第一章 mongo介绍 关系型与非关系型 mongo和mysql数据对比 MongoDB特点 第二章 安装mong...

网友评论

      本文标题:强强对比 MongoDB与MySQL

      本文链接:https://www.haomeiwen.com/subject/hecfsctx.html