MongoDB基础语句及格式

mongoDB基本语句

一、mongo数据指令

1.创建数据库/切换到某个数据库
use 数据库名
2.查看数据库

show dbs

3.查看当前在某个数据库下

db

4.创建数据表

db.createCollection(“集合名”) 集合名即是表名
5.删除数据库

    db.dropDatabase()

6.查看数据表

    show tables/show collections

7.添加数据

    01->添加单挑数据
        db.collecitonName.insert({})
    02->添加多条数据
        db.collecitonName.insert([{},{},{},......])

8.更新数据

01->db.collecitonName.update(condition,{$set:documet})
            #修改和condition条件匹配的数据,只修改单条数据

02->db.collectionName.update(condition,data)
            #直接将匹配到的数据替换成data,只修改单条数据

03->db.collecitonName.update(condition,{$set:data},{multi:true})
            #修改和condition条件匹配的数据,只修改多条数据

04->db.collectionName.save\
({ "_id" : ObjectId("5b02727841001552d7adde9e"),....})
            #修改和给定id相匹配的数据,如果匹配成功,则直接替换

05->db.collecitonName.save({....})
            #如果save不使用id作为查找条件,则直接添加新的数据到表中

9.删除数据

    01->db.collecitonName.remove(condition,justOne)
        condition:删除数据的条件
        justOne:是否只删除一条匹配到的数据
        001->删除匹配到的所有数据
            db.collecitonName.remove(condition)
        002->删除匹配到的第一条数据
            db.collecitonName.remove(condition,true/1)
    02->删除所有的数据
        db.collecitonName.remove({})

10.查询数据

    01->查询所有数据
        db.collecitonName.find()
    02->美化查询得到的数据
        db.collecitonName.find().pretty()
    03->仅查找一条数据
        db.collecitonName.findOne()
    04->条件查找之数学运算符
    操作      语法                  示例                              
    相等      <key>:<value>       where by = 'yiibai'
    小于       {$lt:50}            where likes < 50
    小于等于    {$lte:50}          where likes <= 50
    大于     {$gt:50}            where likes > 50
    大于等于    {$gte:50}          where likes >= 50
    不等于     {$ne:50}           where likes != 50

11.逻辑条件查询

    01->条件与 AND
       db.collecitonName.find({key1:condition1,key2:condition2,....})\
       .pretty()查找同时满足key1的符合condition1并且key2的值符合condition2\
       的所有数据
    02->条件或 OR
        db.collecitonName.find({$or:[condition1,condition2,....]})
        例如:condition1={subject:"语文"},condition2={subject:"化学"}
        查找科目为语文或者化学的所有学生的成绩
    03->AND和OR一起使用
        db.score.find({$or:[{subject:"语文"},\ #换行
        {subject:"化学"}],score:{$gt:87}})
        查找学科为语文或者化学并且分数要大于87分的所有学生的成绩

12mongoDB分页查询

    01->限定查找文档的个数
        db.collectionName.find().linmit(number)
        获取number条数据
        02->跳过若干数据进行数据的查找
        db.collectionName.find().skip(number)

二、 python操作mongo基本格式

from pymongo import MongoClient     #连接mongoDB数据库
connect=MongoClient("localhost")    #关联某个数据库
db=connect.school                   
#连接名点数据库名字  
# 关联的数据库存在,则直接关联;关联的数据库要是不存在,则创建新的数据库
grade_1_3 = db.grade_1_3         #关联数据表的逻辑和关联数据库的逻辑一样
result=grade_1_3.find({},{'_id':0})             #表的相关操作
for document in result:
    print(document)

连接多个

from pymongo import MongoClient
class Connect:
    def __init__(self,dbName,collection):     #里面有一个库
        self.con=MongoClient("localhost")     #连接
        self.db=self.con[dbName]              #关联数据库
        self.collection=self.db[collection]   #连表
    def get(self):
        return self.collection
if __name__=="__main__":
    test=Connect("myschool","grade_1_3").get()
    #创建一个事例,从con中获得一个表的实例
    scores=test.find({},{"_id":0})
    for doc in scores:
        print(doc)
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MongoDB基础语法包括使用条件操作符进行查询。其中包括使用$or操作符实现逻辑或查询。语法格式如下: ``` db.collection.find({ $or: [ { key1: value1 }, { key2: value2 } ] }) ``` 这个查询语句表示在集合中查找满足key1等于value1或key2等于value2的文档。 另外,还可以使用比较操作符进行条件查询。比如使用$lt操作符进行小于操作,$lte进行小于等于操作。例如: ``` db.collection.find({ likes: { $lt: 150 } }) ``` 这个查询语句表示在集合中查找likes字段小于150的文档。 此外,还可以结合多个条件进行查询,使用$or操作符和其他条件操作符一起使用。例如: ``` db.collection.find({ "likes": { $gt: 50 }, $or: [ { "by": "菜鸟教程" }, { "title": "MongoDB 教程" } ] }) ``` 这个查询语句表示在集合中查找likes大于50,并且by等于"菜鸟教程"或者title等于"MongoDB 教程"的文档。 以上就是MongoDB基础语法的简单介绍。根据需要,可以使用不同的条件操作符组合查询条件来满足特定的需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [20201207MongoDB - 创建数据库/删除数据库/创建集合/删除集合/插入文档/更新文档/删除文档/查询文档/条件...](https://blog.csdn.net/weixin_36810906/article/details/110792096)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值