用 pymongo 操作 MongoDB 数据库


作者:SunCOOL,喜欢python,相信python。

基于python3.7.3 64-bit/pymongo3.4

1.连接数据库

你可以使用以下2种方法


   
   
  1. # -*- coding: utf-8 -*-

  2. #导入pymongo中的MongoClient模块

  3. from pymongo importMongoClient

  4. #第一种方法:使用host和port

  5. client1 = MongoClient(host,port)

  6. #这里的host是一个ip地址,可以是本机的127.0.0.1,也可以是一个网络地址,也就是说可以不在安装MongoDB的情况下使用MongoDB

  7. #第二种方法:使用mongodb url

  8. url = 'mongodb://host:port/'

  9. #当数据库有密码的时候

  10. url = 'mongodb://username:password@host:port/'#默认进入admin

  11. client2 = MongoClient(url)

  12. #当MongoDB里面有多个数据库,分别是test1,test2...,可以通过下面的url形式来进行访问特定的数据库

  13. url = 'mongodb://username:password@host/database_name'


2.在增、删、改、查操作之前

也就是说一个MongoDB连接可以有多个database,同一个database下可以有多个collection,一个collection下可以有多个document


   
   
  1. from pymongo importMongoClient

  2. client = MongoClient(host='127.0.0.1',port=27017)

  3. #这个时候我们已经连接上了数据库,但是还不能直接进行具体操作,需要在集合的水平进行具体操作

  4. #建立一个名为china数据库

  5. china = client['china']

  6. #在user的基础上建立一个名为shandong的集合

  7. shandong = china['shandong']

  8. #至此我们可以在集合的基础上进行增、删、改、查的操作了

为了整齐,此处将上面的代码进行整合


   
   
  1. # -*- coding: utf-8 -*-

  2. from pymongo importMongoClient

  3. client = MongoClient(host='127.0.0.1',port=27017)

  4. collection = client['china']['shandong']

下面增、删、改、查的操作都是在上面 collection这个对象的基础上进行操作

3.写(增)操作

pymongo提供了 insert_one()insert_more()两个方法来进行写操作


   
   
  1. #insert_one()接收一个字典对象

  2. collection.insert_one({'people_num':147000000})

  3. #insert_many()接收一个字典列表

  4. collection.insert_many([{'people_num':147000000},{'city_num':16}])

  5. collection.insert_one({'people_num':147000000,'city_num':16,'location':"east"})

效果如下: 

4.查操作

pymongo提供了 find_one()find()两个方法来进行查操作 find_one方法


   
   
  1. #默认获取集合中的第一条

  2. collection.find_one()

  3. #按条件查询,find_one()接收一个字典来进行匹配

  4. collection.find_one({'people_num':147000000})

  5. #多条件查询

  6. collection.find_one({'people_num':147000000,'city_num':16})

find方法


   
   
  1. #获取集合中所有数据

  2. collection.find({})

  3. #按条件查询,find()接收一个字典来进行匹配

  4. collection.find({'people_num':147000000}) #=>返回一个pymongo内置的Cursor对象,是可迭代的,可以使用循环输出

  5. #按规则输出数据项,为1的输出,为0的不输出

  6. collection.find({},{'_id':0,'city_num':1}) #==>含有city_num数据项的输出city_num,没有的输出空字典

  7. collection.find({},{'people_num':0,'city_num':1})#这样写会报错,也就是find({},{query}),query中不能同时含有两个数据项(_id除外)

  8. #限制返回条数 .limit(n)当n大于原本的数据数量时,返回原数据量,当小于时,返回n条

  9. collection.find({}).limit(3) #返回三条

  10. #使用正则查询

  11. collection.find({"location":{ "$regex":"e[a-z]+"}}) #=>匹配location的值是以e开头后面有多个小写字母的=>east

  12. #更高级的查询 使用修饰符

  13. # $gt 匹配大于指定值的值

  14. # $eq 匹配等于指定值的值

  15. # $gte 匹配大于或等于指定值的值

  16. # $in 匹配数组中指定的任何值

  17. # $nin 不匹配数组中指定的任何值

  18. # $lt 匹配小于指定值的值

  19. # $lte 匹配小于或等于指定值的值

  20. # $ne 匹配所有不等于指定值的值

  21. # $and 用逻辑联接查询子句AND将返回两个子句都匹配的所有文档。

  22. # $not 反转查询表达式的效果,并返回与查询表达式不匹配的文档。

  23. # $nor 用逻辑联接查询子句NOR将返回两个子句均不匹配的所有文档。

  24. # $or 用逻辑联接查询子句OR将返回符合任一子句条件的所有文档。

  25. #更多修饰符请看 https://docs.mongodb.com/manual/reference/operator/query/

  26. collection.find({"people_num":{"$eq":147000000}}) #匹配people_num的值等于147000000

5.改(更新)操作

pymongo提供了 update_one()update_many()两个方法来进行查操作


   
   
  1. #更新一条数据

  2. collection.update_one({'people_num':147000000},{"$set": { "people_num": "12345"}})

  3. #更新多条数据

  4. collection.update_many({'city_num':16},{"$set": { "city_num": 100}})

6.删操作

pymongo提供了 delete_one()delete_many()两个方法来进行删除操作,和查操作的使用方法一样。

赞 赏 作 者

Python中文社区作为一个去中心化的全球技术社区,以成为全球20万Python中文开发者的精神部落为愿景,目前覆盖各大主流媒体和协作平台,与阿里、腾讯、百度、微软、亚马逊、开源中国、CSDN等业界知名公司和技术社区建立了广泛的联系,拥有来自十多个国家和地区数万名登记会员,会员来自以工信部、清华大学、北京大学、北京邮电大学、中国人民银行、中科院、中金、华为、BAT、谷歌、微软等为代表的政府机关、科研单位、金融机构以及海内外知名公司,全平台近20万开发者关注。

▼ 点击阅读原文,领取阿里云最高¥2000代金券

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值