mongodb数据库基础入门--学习笔记

mongodb基础入门

mongodb简介

MongoDB是一个跨平台,面向文档的数据库,提供高性能,高可用性和易于扩展。
MongoDB是工作在集合和文档上一种概念

数据库
数据库是一个集合的物理容器。每个数据库获取其自己设定在文件系统上的文件。一个单一的MongoDB服务器通常有多个数据库。

集合
集合是一组键值对。文档具有动态模式。动态模式是指,在同一个集合的文件不必具有相同一组集合的文档字段结构,并且相同的字段可以保持不同类型数据。

示例文档

{
	_id:ObjectId(5d26ed049a31fa88c767d620)
	title:"MongoDB Over View",
	description:"MongoDB is no sql database",
	by:"yiibai tutorial",
	url:"http://www.yiibai.com",
	tags:["mongodb","database","NoSQL"],
	likes:100
   comments: [	
      {
         user:"user1",
         message: "My first comment",
         dateCreated: new Date(2018,1,20,2,15),
         like: 0 
      },
      {
         user:'user2',
         message: 'My second comments',
         dateCreated: new Date(2018,1,25,7,45),
         like: 5
      }
   ]
}

软件安装

Linux:
sudo apt install mongodb
netstat -ant |grep 27017

Windows:
mongodb数据库下载
如果链接不可用,请使用以下网址:
https://www.mongodb.org/dl/win32/x86_64-2008plus-ssl
启动数据库前,需要添加环境变量

mongo

一、操作mongodb数据库
1、创建数据库

语法:use数据库名
注意:如果数据库不存在则创建数据库,否则切换到指定的数据库
注意:如果刚刚创建的数据库不在列表内,如果要显示它,我们需要向刚刚创建的数据库中插入一些数据

use shool
db.student.insert({name:"tom",age:18,gender:1,address:"北京",usDelete:0})
2、删除数据库

#前提:使用当前数据库(use 数据库名)

db.dropDatabase()
3、查看所有数据
show dbs
4、查看当前正在使用的数据库
db
or
db.getName()
5、断开连接
exit
6、查看命令api
help
二、集合操作
1、查看当前数据库下有哪些集合
show collections
2、创建集合

语法:db.集合名.insert(文档)

db.student.insert({name:"zh",age:20,gender:1,address:"深圳",isDelete:0})

此时会创建一个student的集合

3、删除数据库中的集合

语法:db.集合名.drop()

db.student.drop()
三、文档操作
1、插入文档

使用insert()方法
语法:db.集合名.insert(文档)
语法:db.集合名.insert(文档1,文档2,文档3,…文档n)

插入一个学生

db.student.insert({name:"lilei",age:19,gender:0,address:"北京",isDelete:0})

插入多个学生

db.student.insert([{name:"海妹妹", age:17, gender:0,address:"北京", isDelete:0},{name:"韩梅梅", age:20, gender:0,address:"上海", isDelete:0}])

使用save()方法
语法:db.集合名.save(文档)
说明:如果不指定_id字段,save()方法类似于insert()方法,如果指定id字段,则会更新_id字段的数据

db.student.save({name:"poi", age:22, gender:1,address:"石家庄", isDelete:0})
db.student.save({_id:ObjectId("59950962019723fe2a0d8d17"),name:"poi", age:23, gender:1,address:"石家庄", isDelete:0})
2、文档更新

update()
语法:

db.集合名.update(
            query,
            update,
            {
                upsert:<boolean>,
                multi:<boolean>,
               
            }
        )

参数说明:

query:update的查询条件,类似于sql里update语句内where后面的内容

update:update的对象和一些更新的操作符($set,$inc)等,$set直接更新,
$inc在原有的基础上累加后更新

upset:可选属性,如果不存在update的记录,是否当新数据插入,true为插入,false为不插入,默认为false

multi:可选属性,mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就按照条件查找出来的数据全部更新

需求:将lilei的年龄更新为25
db.student.update({name:"lilei"},{$set:{age:25}})
需求:将lilei的年龄加25岁
db.student.update({name:"lilei"},{$inc:{age:25}})
将名字为poi的同学的年龄全部修改为42岁
db.student.update({name:"poi"},{$set:{age:42}},{multi:true})

#不插入,更新多条
db.student.update({name:"zh",age:20},{$set:{name:"zsq"}},false,true)

#如果匹配不到就插入,如果匹配到了就更新多条
db.student.update({name:"zh",age:20},{$set:{name:"zsq"}},true,true)
3、文档的删除

说明:在执行remove()函数前,先执行find()命令来判断执行的条件是否存在是一个良好习惯
语法:

 db.集合名.remove(
            query,
            {
                justOne:<boolean>,
            }
        )

参数说明:
query:可选,删除文件的条件
justOne:可选,如果为true或1,则只删除一个文档

db.student.remove(name:"poi")
4、文档查询

find()
语法:db.集合名.find()
查询集合下所有的文档(数据):

db.student.find()

find()方法查询指定列
语法:

db.集合名.find(
            query,
            {
                <key>:1,
                <key>:1
            }
        )

参数说明:
query:查询条件
key:要显示的字段,1表示显示

db.student.find({gender:0},{name:1,age:1})
db.student.find({},{name:1,age:1})

pretty()方法以格式化的方式来显示文档

db.sutdent.find().pretty()

findOne()方法查询匹配结果的第一条数据

db.student.findOne({gender:0})
5、查询条件操作符

作用:条件操作符用于比较两个表达式并从Mongodb集合中获取数据
大于-$gt

#语法:
db.集合名.find({<key>:{$gt:<value>}})
#示例:
db.student.find({age:{$gt:20}})

大于等于-$gte

语法:
db.集合名.find({<key>:{$gte:<value>}})

小于-$lt

#语法
db.集合名.find({<key>:{$lt:<value>}})

小于等于-lte

#语法:
db.集合名.find({<key>:{$lte:<value>}})

大于等于和小于等于 -$glt和-$lte

#语法
db.集合名.find({<key>:{$gte:<value>,$lte:<value>}})

等于 -:

#语法
db.集合名.find({<key>:<value>})

使用_id进行查询

#语法
db.student.find({"_id":ObjectId("id值")})

#示例
db.student.find({"_id":ObjectId("5995084b019723fe2a0d8d14")})

查询某个结果集的数据条数

db.student.find().count()

查询某个字段的值当中是否包含另一个值

示例
db.student.find({name:/ile/})

查询某个字段的值是否以另一个值开头

#示例
db.student.find({name:/^li/})
6、条件查询 and 和 or

and

#语法
db.集合名.find({条件1,条件2,...条件n})

#示例
db.student.find({gender:0,age:{$gt:16}})

or

 #语法:
            db.集合名.find(
                {
                    $or:[{条件1},{条件2},……,{条件n}]
                }
            )
            
#示例:
db.student.find({$or:[{age:17},{age:{$gte:20}}]})

and和or联合使用

#语法:
	db.集合名.find(
                {
                    条件1,
                    条件2,
                    $or:[{条件3},{条件4}]
                }
            )
7、limit、skip

limit:读取指定数量的数据记录

db.student.find().limit(3)

skip():跳过指定数量的数据

db.student.find().skip(3)

skip与limit联合使用
通过用这种方式来实现分布功能

db.student.find().skip(3).limit(3)
8、排序
#语法:
db.集合名.find().sort({<key>:1|-1})
示例:
db.student.find().sort({age:1})

注意:1表示升序,-1表示降序

此文章引用于千锋

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值