数据库-2

mongodb数据库是什么

数据库:数据库是结构化信息的集合。数据库系统包含两方面:

1.库 2.库的管理系统

Collection(表)

表是用来存储数据,一个数据库里可以有多个表。一个表就是document的集合。表里存储的是一条一条的记录,这个记录被称为"document"

document(记录):表示一条数据的记录。在MongoDB数据库中,document通常存储着一个对象。

MongoDB是一种NOSQL风格的数据库

  • Not Only SQL 不仅仅是结构化查询语言

SQLServer和mySQL都属于SQL(结构化查询语言)风格的数据库

BOSN:

Binary JSON的缩写。翻译:二进制存储的JSON

MongoDB数据库由以下几部分构成

  • 数据库(Database)
    • 表(collection)
      • 记录(document)
        • 字段
        • 字段
      • 记录(document)
    • 表(collection)
      • 记录(document)

数据库的CRUD操作

C:Create 增

R:Retrieve 查

U:Update 更新

D:Drop 删除

db.collection.inserOne()

定义:用于向数据库表里添加一条记录

语法:

db.表名.inserOne({})//参数的语法符合JS对象的语法

返回值:返回一个对象,该对象有两个属性

{
    acknowledge:boolean,//true表示数据被认可
    insertedIds: ObjectId('字符串id')//由系统自动分配的该记录id
}

db.collection.inserMany()

定义:用于向数据库表里添加一组记录

语法:

db.表名.inserMany([{document},{document},{document}])//参数的语法符合js对象的语法

返回值:返回一个对象,该对象有两个属性

{
    acknowledge:boolean,//true表示数据被认可
    insertedIds: ObjectId('字符串id')//由系统自动分配的该记录id
}

db.collection.find()

定义:用于检索/查询数据库表里的记录

语法:

db.表名.find()//无参数  , 检索表中的全部记录 。 默认每次最多20条记录
# 查看下一组20条数据
it//只需输入it,回车就可以翻页(it:iterate   迭代)
db.表名.find({queryobject})//queryObject:查询条件对象   按条件检索

返回值:返回检索的数据记录

示例:

db.collection.find({字段})

用法:

1.insertOne() 可以同时插入多个文档

2.insertMany() 将数组中的每个文档插入集合中

3.find():查询所有

4.find({字段1})单条件查询

5.find({字段1,字段2}) 多条件查询

6.find({条件查询对象},{检索限制对象})

7.find({},{title:1,content:1})

  findOne({条件查询对象})返回匹配到的第一条记录

8.db.表名.deleteMany({}) 删除多条记录

9.db.表名.deleteOne() 删除单挑记录

10.db.表名.find().count() 查询记录条数

11.db.表名.find().limit(3) 查询指定的条数

字段

字段就是字段名:字段值

{
字段名1: 字段值1,
字段名2: 字段值2,
title: '标题'
}

db.collection.find().sort({字段名:-1})

  • 1 升序排列
  • -1 降序排列

操作符

MongoDB中提供了许多操作符,操作符的表示:$开头

操作符是字段名

$操作符:()
  • $gt:大于过滤器
  • $lt:小于
  • $gte:大于等于
  • $lte:小于等于
  • $or:或 (满足其中一个字段的元素数据)
  • $set:设置
  • $and 且
  • $in 包含 (满足其中一个元素的数据)
  • $nin 不包含

$gt语法

db.collection.find({字段名:{$gt:字段值}})

$lt语法

db.collection.find({字段名:{$lt:字段值}})

$gte语法

db.collection.find({字段名:{$gte:字段值},author:"张三"})

$or语法

db.collection.find({$or:[{author:"小米"},{author:"小王"}]})

$and语法

db.collection.find({$and:[{author:"小米"},{like:100}]})

$in语法

db.collection.find({like:{$in:[100,488,788]}})

$nin语法

db.collection.find({like:{$nin:[100,488,788]}})

db.collection.updateOne({更新哪个},{更新内容}

定义:用于更新一条数据

db.collection.updateOne({_id: ObjectId("640fe6b8ec6bf627e52322a9")},{$set:{author:"大米",like:1200}})
db.collection.updateOne({author: '小米',},{更新内容}

db.collection.updateMany()

定义:用于更新多条数据

db.collection.updateMany({author:"张三"},{$set:{author:"老王"}})

db.collection.updateMany({},{$set:{"phone":'17872605311'}},b1,b2)

  • b1:为true时表示,在没有匹配到记录时创建一个新的记录,false:不创建新记录
  • b2:为true表示批量,false表示一个

db.collection.updateMany({},{$set:{"phone":'17872605311'}},b1,b2)

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容

  • 上一篇了解了Mongodb基本常识,下面继续: 一、查询语句: find() 用法: 查询数据,不加任何参数默认返...
    多了去的YangXuLei阅读 444评论 0 3
  • 一、MongoDB简介 概述MongoDB是一个基于分布式文件存储的数据库,由C++语言编写。旨在为WEB应用提供...
    土卡拉阅读 161评论 0 0
  • 总体内容 一、数据准备、基本的查询 二、条件查询 三、排序 四、聚合、分组 五、分页 六、连接查询(多表的时候有用...
    IIronMan阅读 4,449评论 1 10
  • SQL 约束(Constraints) SQL 约束用于规定表中的数据规则。如果存在违反约束的数据行为,行为会被约...
    allen151阅读 288评论 0 0
  • 变量Mysql本质是一种编程语言,需要很多变量来保存数据。Mysql中很多的属性控制都是通过mysql中固有的变量...
    4F4C阅读 389评论 0 0