MongoDB的基本指令

1 数据更新
   
   
var model = db.person.findOne({"name":"jack"})
model.age= 30
db.person.update({"name":"jack"},model)
     
     
db.person.update({"name":"jock"},{$inc:{"age":30}}) #名为jack的用户的age增加30
db . person . update ({ "name" : "jock" },{ $set :{ "age" :1 0 }}) #名为jack的用户的age变成10
db . person . update ({ "name" : "jockson" },{ $set :{ "age" :1 0 },true} # 名为更新jockson的用户,若没有则添加该用户
      
      
删除用户
db.person.remove({"age":"jack"},{"age":20})

2:聚合操作
常见的聚合操作有: count、distinct、group、mapReduce
   
   
       
       
count
db.person.count() 查询collectionperson里面的数据有几条
distinct
db.person.distinct("age") 显示不同的记录集

3:性能分析函数
   
   
插入数据
for(car i=0;i<100000;i++){
var rand=parseInt(i*Math.random());
db.person.insert("name":"hxc"+i,"age":i)}
 
显示数据
db.person.find({"name":"hxc"+10000}).explain()
4:删除集合
   
   
db.collections.drop()
其中collections是集合的名字

1  use admin        #进入到系统admin用户里面,其包含包含了一个system.user表,这个表就等同于MsSql中的用户表,用来存放超级管理员的

        2   创建新的用户

   
   
db.createUser( { "user" : "liu","pwd": "liu",roles" : [ { role: "clusterAdmin", db: "admin" }] } )
        3:关闭mongodbserver
   
   
db.shutdownServer()
        4: 查看mongdb进程(一般不出现)
   
   
ps aux | grep mongo 或者 ps -ef | grep mongo
   
      5:删除进程
    
    
kill -2 132554

   6:编辑mongod.conf
                  

    7:再次开启mongodb
   
   
mongod -f mongodb/mongod.conf --fork
    8 :  开启mongo客户端
   
   
mongo
    9:进入admin用户
    
    
use admin
    10:认证用户
    
    
db.auth("liu","liu")

11:为普通数据库添加用户权限
    
    
db.createUser({
user:"liu" #用户名称
pwd:"liu",#用户密码
roles:[{role:"readWrite",db:"tbm"}] #其中的db为所建的那个数据库下的用户,role为用户的权限
})
12:删除创建的用户
    
    
进入到创建用户的数据库,进行如下执行
db.dropUser("liu",{w:"majority",wtimeout:5000})
     
     
删除所在数据库下所有的用户
dropAllUsers({w:"majority",wtimeout:5000})
13:更改用户密码
    
    
db.changeUserPassword("liu","123")#更改用户的密码为123
14:得到用户的详细信息
    
    
db.getUser("liu")
db.getUsers()

1 创建数据库
    
    
use 数据库名
2 创建表
    
    
use 表名 insert ({})
3:查询数据
    
    
# use .表名. find ()
4:强制执行
    
    
. hint ()
5: 2d索引
    
    
创建
db . location . ensureIndex ({ w : "2d" })
查找
db.location.find({$near:[1,1],$maxDistance:10})
db.location.find({w:{$geoWithin:{$box:[[x1,y1],[x2,y2]]}}})查询矩形[x1,y1],[x2,y2]内的数据
db.location.find({w:{$geoWithin:{$center:[[x1,y1],r]}}}) 查询圆心为[x1,y1],半径为r的圆内的数据点
db.location.find({w:{$geoWithin:{$polygon:[[x1,y1],[x2,y2],[x3,y3],[x4,y4]]}}})查询多边形[x1,y1],[x2,y2],[x3,y3],[x4,y4]]内部的数据点

6:2dsphere索引
    
    
db . collection . ensureIndex ({ w : "2dsphere" })
7:集合的操作
    
    
创建集合
db . createCollection ( "users" )
显示集合
show collections
删除集合
db . users . drop ()
插入数据
db.users.insert([ { name : "jam" , email : "jam@qq.com" }, { name : "tom" , email : "tom@qq.com" } ])
8:save和insert的区别
    
    
save是原来的对象不存在的话,会向collection里面写入新的对象和数据。
insert是向已知表格直接插入数据,不在遍历列表。save需要遍历列表,效率较低
9:查询
    
    
db.users.find().pretty()
其中的pretty()函数使得输出结果更加美观
10:符号表示
    
    
{$gt:10}表示大于10
{$lt:10}表示小于10
{$lte:10}表示小于等于10
{$ne:10}表示不等于10
11:mongodb的聚合aggregate
    
    
aggregate主要用于处理数据(统计平局值、求和等)并返回计算后的数据结果。
eg
db.users.aggregate({$match:{x:1},{limit:NUM},$group:{_id:$age}})
其中:$match:查询,跟find类似
$limit:限制显示结果数量
$skip:忽略结果数量
$sort:排序
group:按照给定的表达式组合结果
12:fork
    
    
fork是开启新的进程
13:更新
    
    
db.person.update({"name":"joe"},{"name":"joe","age":30})
namejoe的用户的年龄更新为30


以下是在 Linux 上操作 MongoDB基本命令: 1. 启动 MongoDB 服务器 在 Linux 上启动 MongoDB 服务器,可以使用以下命令: ``` sudo systemctl start mongod ``` 2. 停止 MongoDB 服务器 要停止 MongoDB 服务器,可以使用以下命令: ``` sudo systemctl stop mongod ``` 3. 连接 MongoDB 数据库 可以使用以下命令连接到 MongoDB 数据库: ``` mongo ``` 可以通过指定 IP 地址和端口号来连接到远程 MongoDB 数据库: ``` mongo <host>:<port>/<database> ``` 4. 显示数据库列表 使用以下命令显示 MongoDB 中的数据库列表: ``` show dbs ``` 5. 创建数据库 可以使用以下命令创建新的 MongoDB 数据库: ``` use <database> ``` 6. 显示集合列表 使用以下命令显示当前数据库中的集合列表: ``` show collections ``` 7. 插入文档 可以使用以下命令向集合中插入新的文档: ``` db.<collection>.insert(<document>) ``` 8. 查询文档 可以使用以下命令查询集合中的文档: ``` db.<collection>.find(<query>) ``` 其中,`query` 参数是一个文档,用于指定查询条件。 9. 更新文档 可以使用以下命令更新集合中的文档: ``` db.<collection>.update(<query>, <update>) ``` 其中,`query` 参数用于指定要更新的文档,`update` 参数用于指定更新的内容。 10. 删除文档 可以使用以下命令删除集合中的文档: ``` db.<collection>.remove(<query>) ``` 其中,`query` 参数用于指定要删除的文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值