Mongodb的基本语法
前段时间工作上面由于没有多少事所以玩了玩mongodb,学习了它的基本语法,然后现在在这里做一个简单的总结。
1.我是在win平台上面,启动的话比较麻烦,所以我就简单的把启动过程做了个批处理文件
启动脚本
:启动mongodb的批处理文件,到mongodb的bin目录下面
D:
cd "Program Files"
cd MongoDB\Server\3.2\bin
:其中D盘下面的data,db目录是自己手动创建的
:启动带有的参数 --auth(开启用户访问权限)
:--dbpath(数据存储路径)
mongod.exe --auth --dbpath D:\data\db
2.一些简单基本语法
#创建或者切换数据库
use admin
#查询方法
db.system.users.find()
#格式化的查询结果
db.userinfo.find().pretty() 查询比较符
等于 {<key>:<value>} db.col.find({"by":"菜鸟教程"}).pretty() where by = '菜鸟教程'
小于 {<key>:{$lt:<value>}} db.col.find({"likes":{$lt:50}}).pretty() where likes < 50
小于或等于 {<key>:{$lte:<value>}} db.col.find({"likes":{$lte:50}}).pretty() where likes <= 50
大于 {<key>:{$gt:<value>}} db.col.find({"likes":{$gt:50}}).pretty() where likes > 50
大于或等于 {<key>:{$gte:<value>}} db.col.find({"likes":{$gte:50}}).pretty() where likes >= 50
不等于 {<key>:{$ne:<value>}} db.col.find({"likes":{$ne:50}}).pretty() where likes != 50
#查询年纪大于等于25的信息
db.userinfo.find({"age":{$gte:25}}).pretty() #查询age字段是String类型的记录。显示的结果集(默认显示_id字段)只有user_name和age这两个字段。
db.userinfo.find({"age":{$type:2}},{_id:0, "user_name":1, "age":1}) #删除用户
db.dropUser('root')
#创建新的用户 db.createUser({'user':'root', 'pwd':'000000','roles':[{'role':'readWrite', 'db':'mytest'}, {'role':'readWrite', 'db':'admin'}]}) #mongodb创建集合对象 db.XXX:表示如果XXX存在则往这里直接插入数据,如不存在,则创建对应的集合
#插入数据 db.COLLECTION_NAME.insert(document)
db.userinfo.insert([{user_name:'1', age:10, sex:1},{user_name:'2', age:10, sex:0}])
#mongodb更新语句更新单条语句 如果 $set字段不存在,若键不存在,会新建
db.item_info.update({"item_id":"c9aea5ea-c29d-43ec-8205-fdb1e69934b7"},{$set:{"item_name":"test_update", "test":"test_add"}})
$unset关键字,删除对应的key值
去除【item_name】、【test】这两个key
db.item_info.update({"item_id":"c9aea5ea-c29d-43ec-8205-fdb1e69934b7"},{$unset:{"item_name":"test_update", "test":"test_add"}}) #mongodb更新语句更新多条语句
db.userinfo.updateMany({"user_name":"1"}, {$set:{"user_name":"nie"}})
#更新age字段<= 20的字段为wewe值
db.userinfo.updateMany({"age":{$lte:20}}, {$set:{"age":"wewe"}}) #mongodb删除语句
db.userinfo.remove({"user_name":"2"}) 删除所有数据
db.userinfo.remove({}) #type
$type操作符是基于BSON类型来检索集合中匹配的数据类型,并返回结果。
// 查询age字段是string类型的所有记录
db.userinfo.find({"age":{$type:2}})
最大范围
- 集合中索引不能超过64个
- 索引名的长度不能超过125个字符
- 一个复合索引最多可以有31个字段


#删除
db.item_info.deleteOne({"item_name":"update_item_name"})
db.item_info.find({"item_name":"update_item_name"}).count()
DeleteResult delete = item.deleteMany(Filters.eq("item_name", "update_item_name"));
System.out.println(delete.getDeletedCount()); #mongodb语句explain
> db.item_info.find({}).explain()
{
"queryPlanner" : {
"plannerVersion" : 1,
"namespace" : "test.item_info",
"indexFilterSet" : false,
"parsedQuery" : {
"$and" : [ ]
},
"winningPlan" : {
"stage" : "COLLSCAN",
"filter" : {
"$and" : [ ]
},
"direction" : "forward"
},
"rejectedPlans" : [ ]
},
"serverInfo" : {
"host" : "Lenovo-niejian",
"port" : 27017,
"version" : "3.2.8",
"gitVersion" : "ed70e33130c977bda0024c125b56d159573dbaf0"
},
"ok" : 1
} #mongodb语句like(正则表达式) 如果检索需要不区分大小写,我们可以设置 $options 为 $i。
以下命令将查找不区分大小写的字符串 w3cschool.cc db.posts.find({post_text:{$regex:"w3cschool.cc",$options:"$i"}}) db.item_info.find({"item_id":{$regex: /c9aea5ea/}})
Mongodb的基本语法的更多相关文章
- MongoDB update数据语法【转】
在前面的文章“mongodb 查询的语法”里,我介绍了Mongodb的常用查询语法,Mongodb的update操作也有点复杂,我结合自己的使用经验,在这里介绍一下,给用mongodb的朋友看看,也方 ...
- Mongodb与mysql语法比较
Mongodb与mysql语法比较 mongodb与mysql命令对比 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由 ...
- mongodb查询的语法(大于,小于,大于或等于,小于或等于等等)
1 ) . 大于,小于,大于或等于,小于或等于 $gt:大于$lt:小于$gte:大于或等于$lte:小于或等于 例子: db.collection.find({ "field" ...
- mongodb常用查询语法
一.查询 find方法 db.collection_name.find(); 查询所有的结果: select * from users; db.users.find(); 指定返回那些列(键): se ...
- mongoDB的常用语法
安装: 到mongodb官网下载安装包或者压缩包:https://www.mongodb.com/download-center?jmp=nav 1.如果是msi包的话则点击按步骤安装,如果是压缩包的 ...
- mongoDB 高级查询语法
http://www.cnblogs.com/ITAres/articles/2084794.html本文参考自官方的手册:http://www.mongodb.org/display/DOCS/Ad ...
- MongoDB 常用查询语法
一.查询 find方法 db.collection_name.find(); 查询所有的结果: select * from users; db.users.find(); 指定返回那些列(键): se ...
- mongodb driver c#语法
Definitions and BuildersThe driver has introduced a number of types related to the specification of ...
- mongodb 的基本函数语法封装
//这个模块里面封装了所有对数据库的常用操作 var MongoClient = require('mongodb').MongoClient; var config = require(" ...
随机推荐
- ScriptOJ-safeGet#99
const safeGet = (data, path) => { if(!path) return undefined; const pathArr = path.split('.'); le ...
- Html5与Css3知识点拾遗(四)
web图像 JPEG:适用于大多数照片,颜色较多,可接受质量损失的图像 PNG-8:适用标识.重复的图案以及其他颜色较少的图像或具有连续颜色的图像 PNG-24:不支持颜色更多的图像,适用与颜色丰富且 ...
- 前端vue框架 脚手架
1.安装node.js最新版本2.cmd下输入 1.node -v得到版本号检测是否安装成功 版本号要在6.9以上 2.npm -v 版本号要在3.10以上3.安装脚手架 1.npm install ...
- js五道经典练习题--第五道成绩列表
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...
- MySQL 数据类型说明解释
在 MySQL 中,有三种主要的类型:Text(文本).Number(数字)和 Date/Time(日期/时间)类型. Text 类型: 数据类型 描述 CHAR(size) 保存固定长度的字符串(可 ...
- httpd: apr_sockaddr_info_get() failed for bogon
AH00557: httpd: apr_sockaddr_info_get() failed for bogon AH00558: httpd: Could not reliably determin ...
- 从理论到实践 全面理解HTTP/2
前言 为了降低加载时间,相信大多数人都做过如下尝试 Keep-alive: TCP持久连接,增加了TCP连接的复用性,但只有当上一个请求/响应完全完成后,client才能发送下一个请求 Pipelin ...
- Dispatch Queue 之内存中常驻的几个结构
_dispatch_main_q 也就是主要主队列,一定运行在主线程里. // 6618342 Contact the team that owns the Instrument DTrace pro ...
- python网络编程初级
网络编程的专利权应该属于Unix,各个平台(如windows.Linux等).各门语言(C.C++.Python.Java等)所实现的符合自身特性的语法都大同小异.在我看来,懂得了Unix的socke ...
- [EXP]Huawei Router HG532e - Command Execution
#!/bin/python ''' Author : Rebellion Github : @rebe11ion Twitter : @rebellion ''' import urllib2,req ...