MongoDB CRUD之C

Posted onetoinf

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MongoDB CRUD之C相关的知识,希望对你有一定的参考价值。

数据库操作

命令 操作
db 查看当前数据库
show dbs 查看当前端口有多少数据库
use db_name 切换数据库,没有数据库时自动创建
db.dropDatabase() 删除数据库

其他的命令可以使用db.help()或者官网查看

集合操作

命令 操作
db.collection_name.insert(doc) 会在插入文档时自动创建集合
db.collection_name.drop() 删除集合
show collections 显示当前数据库中的集合

其他的命令可以使用db.mycoll.help()查看或者官网查看

文档插入

命令 操作
db.createCollection(name, {size: ., capped: ., max: .} ) 创建指定数据库
db.collection.insertOne() 将单个文档插入到集合中。
db.collection.insert() 将单个文档或多个文档插入到集合中。
db.collection.insertMany() 将多个文档插入到一个集合中。

Create

  • 数据库

    • 创建或者切换数据库

      $ mongo
      1 > use company
      switched to db company
      2 > db
      company
      3 >
    • 查看当前或者所有数据库

      2 > db
      company
      3 > show dbs
      admin  0.000GB
      local  0.000GB
      test   0.000GB
      4 >

      注因为当前数据库中没有数据,所以查看不到

    • 删除数据库

      4 > db
      company
      5 > db.dropDatabase()
      { "ok" : 1 }
      6 > db
      company
      7 >

      删除完当前数据库后,很奇怪的是当前数据库仍然是company

  • 集合

    • 插入文档并自动创建集合

      11 > db.unicorns.insert({
      ...      name: 'Aurora',
      ...      gender: 'f',
      ...      weight: 450
      ... })
      WriteResult({ "nInserted" : 1 })

      插入文档后由于有了数据,所以查看得到了数据库

      12 > show dbs
      admin    0.000GB
      company  0.000GB
      local    0.000GB
      test     0.000GB
    • 显示当前数据库中的集合

      13 > show collections
      unicorns
    • 列表显示集合名字

      14 > db.getCollectionNames()
      [ "unicorns" ]
    • 删除集合

      15 > db.unicorns.drop()
      true
      16 > show collections
      17 > db.getCollectionNames()
      [ ]
      18 >
  • 文档

    • 插入一条数据

      18 > db.unicorns.insert({
      ...      name    : 'Aurora',
      ...      gender  : 'f',
      ...      weight  : 450
      ... })
      WriteResult({ "nInserted" : 1 })
    • 插入多条数据

      插入数据太多,使用js文档

      db.unicorns.insertMany([
          {
              name: 'Horny',
              dob: new Date(1992,2,13,7,47),
              loves: ['carrot','papaya'],
              weight: 600,
              gender: 'm',
              vampires: 63},
      
          {
              name: 'Aurora',
              dob: new Date(1991, 0, 24, 13, 0),
              loves: ['carrot', 'grape'],
              weight: 450,
              gender: 'f',
              vampires: 43},
          {
              name: 'Unicrom',
              dob: new Date(1973, 1, 9, 22, 10),
              loves: ['energon', 'redbull'],
              weight: 984,
              gender: 'm',
              vampires: 182},
          {
              name: 'Roooooodles',
              dob: new Date(1979, 7, 18, 18, 44),
              loves: ['apple'],
              weight: 575,
              gender: 'm',
              vampires: 99},
          {
              name: 'Solnara',
              dob: new Date(1985, 6, 4, 2, 1),
              loves:['apple', 'carrot',
              'chocolate'],
              weight:550,
              gender:'f',
              vampires:80},
          {
              name:'Ayna',
              dob: new Date(1998, 2, 7, 8, 30),
              loves: ['strawberry', 'lemon'],
              weight: 733,
              gender: 'f',
              vampires: 40},
          {
              name:'Kenny',
              dob: new Date(1997, 6, 1, 10, 42),
              loves: ['grape', 'lemon'],
              weight: 690,
              gender: 'm',
              vampires: 39},
          {
              name: 'Raleigh',
              dob: new Date(2005, 4, 3, 0, 57),
              loves: ['apple', 'sugar'],
              weight: 421,
              gender: 'm',
              vampires: 2},
          {
              name: 'Leia',
              dob: new Date(2001, 9, 8, 14, 53),
              loves: ['apple', 'watermelon'],
              weight: 601,
              gender: 'f',
              vampires: 33},
          {
              name: 'Pilot',
              dob: new Date(1997, 2, 1, 5, 3),
              loves: ['apple', 'watermelon'],
              weight: 650,
              gender: 'm',
              vampires: 54},
          {
              name: 'Nimue',
              dob: new Date(1999, 11, 20, 16, 15),
              loves: ['grape', 'carrot'],
              weight: 540,
              gender: 'f'},
          {
              name: 'Dunx',
              dob: new Date(1976, 6, 18, 18, 18),
              loves: ['grape', 'watermelon'],
              weight: 704,
              gender: 'm',
              vampires: 165}
      ])

      Mongo shell使用load("insertM.js")

      19 > load("insertM.js")
      true
      20 > db.unicorns.find()
      { ..., "name" : "Aurora", "gender" : "f", "weight" : 450 }
      { ..., "name" : "Horny", "dob" : ISODate("1992-03-12T23:47:00Z"), ...}
      { ..., "name" : "Aurora", "dob" : ISODate("1991-01-24T05:00:00Z"), ... }
      ......
      21 > db.unicorns.count()
      13

      可以看到插入了13条数据

    • 插入多条或者一条数据使用insert

      • 插入一条时语法与insertOne一样
      • 插入多条时语法与insertMany一样
    • 循环插入多条数据

      22 > for(i = 3; i < 100;  i ++)db.set2test.insert({x:i})
      WriteResult({ "nInserted" : 1 })
      23 > db.set2test.count()
      97

      可以看到使用了循环插入并创建集合 set2test ,插入完成后集合中有了97条数据

      ?

以上是关于MongoDB CRUD之C的主要内容,如果未能解决你的问题,请参考以下文章

MongoDB 学习笔记之 基本CRUD

MongoDB CRUD之R

MongoDB CRUD之U

MongoDB CRUD之D

《MongoDB入门教程》第06篇 CRUD之创建文档

《MongoDB入门教程》第06篇 CRUD之创建文档