Pyhton

Python操作MongoDB

2019-12-18  本文已影响0人  HeloWxl

1、目录

2、连接数据库

'''
    连接MongoDB数据库的两种方式
    1.无用户认证
    2.用户认证
'''

2.1 无用户认证

from pymongo import MongoClient

# 创建对象,连接本地的数据库(无用户认证)
# 方法一
client = MongoClient()

# 方法二
client1 = MongoClient('localhost',27017)

# 方法三
client2 = MongoClient('mongodb://localhost:27017')

# 连接数据库

db = client['db']

# 连接集合user,集合类似于关系数据库的数据表
# 如果集合不存在的情况下,就会新创建集合user

user_collection = db.user

2.2 用户验证

# 用户认证一
client3 = MongoClient()
db_auth = client3.admin
db_auth.authenticate('username','password')
db = client3['db']

# 用户认证二
client4 = MongoClient('mongodb://username:password@localhost:27017')
db = client4['db']

3、添加数据

3.1 单条数据

# 用户信息
user_info = {
    'name':'wangxianlin',
    'age':22,
    'hobbies':[
        'LOL','Movie'
    ],
    'addr':{
        'country':'China',
        'city':'合肥'
    }
}
# 插入数据库 单条插入,并返回_id
user_id = mdb_collection.insert_one(user_info).inserted_id
print(user_id)
image.png

3.2 多条数据插入

# 插入数据库 多条插入
user_infos = [{
    'name':'wanglong',
    'age':22,
    'hobbies':[
        'LOL','Movie','play cs','cs go'
    ],
    'addr':{
        'country':'China',
        'city':'北京'
    }
},
{
    'name':'Helos',
    'age':23,
    'hobbies':[
        'LOL','Movie','dota'
    ],
    'addr':{
        'country':'China',
        'city':'上海'
    }
}
]
# 插入多条数据,同时获取到插入的_id
user_ids = mdb_collection.insert_many(user_infos).inserted_ids
print(user_ids)
image.png

4、更新数据

常用的更新操作符:

    1. $set : 用来指定一个键的值,如果这个键不存在,就创建它,如果存在,就执行更新。
    2. $unset: 从文档中移除指定的键
    3. $inc: 修改器用来增加已有键的值,或者在键不存在时创建一个键。只能用于证书,长整数或者双精度浮点数。要是用在其他类型的数据上,就会导致操作失败。
    4. $rename: 操作符可以重命名字段名称,新的字段名称不能和文档中现有的字段名相同。如果文档中存在A,B字段,将B字段重命名为A字段,$rename会将A字段和值移除掉,然后将B字段名修改为A。
    5. $push: 如果指定的键已经存在,就会向已有的数组末尾加入一个元素;如果指定的键不存在,就会创建一个新的数组。

4.1 更新单条文档

mdb_collection.update_one(
    {},#筛选条件
    {
        "$set":{'age':18,'name':'HeloWxl'}#更新内容
    }
)
#查询更新后的文档
result = mdb_collection.find(
    {"_id":123}
)
print(list(result))

4.2 更新多条文档

mdb_collection.update_many(
    {
        "age":{"$gte":18}

     },#筛选条件
    {
        "$set":{'age':18}#更新内容
    }
)

# 查询出年龄大于18的用户
result = mdb_collection.find(
    {
        "age":{"$gte":18}
    }
)
print(list(result))

5、查询数据

5.1 普通查询

查询关键字:find

#如果查询的条件为空的时候,则默认为查询全部的数据
result = mdb_collection.find(
    {}
)
print(list(result))
image.png
#查询_id = 123的数据
result = mdb_collection.find(
    {'_id':123}
)
print(list(result))

5.2 多条件查询

# $and  and操作符    $or or 操作符
#$and 操作符
result = mdb_collection.find(
    {"$and":[{'_id':123,'name':'HeloWxl'}]}
)
print(list(result))

#$or 操作符
result = mdb_collection.find(
    {"$or":[{'name':'HeloWxl'},{'name':'Helos'}]}
)
print(list(result))
$lt 小于
$lte 小于等于
$gt 大于
$gte 大于等于
$in (in,符合范围内)
$nin (not in ,范围之外)
#$lt $gt 操作符
result = mdb_collection.find(
    {
        "age":{"$lt":30,"$gt":20}
    }
)
print(list(result))   
  
#$in 操作符
result = mdb_collection.find(
    {
        "age":
            {
            "$in":[18,20,30]
            }
    }
)
print(list(result)) 

比较查询和多条件查询存在明显的区别:

5.3 模糊查询

模糊查询实际上是加入正则表达式实现

#方法一
result = mdb_collection.find(
    {
        "name":{"$regex":'.*xianlin.*'}
    }
)
print(list(result))

import re
# 方法二
regex = re.compile('.*xianlin.*')
result = mdb_collection.find(
    {
        "name":regex
    }
)
print(list(result))

6、嵌套文档/查询嵌入

#查询 addr : {city:'合肥'}
#查询嵌套的字段,只需要查询嵌套的某个值即可
result = mdb_collection.find(
    {'addr.city':'合肥'}
)
print(list(result))

# 如果在addr里面还嵌套一个文档
result = mdb_collection.find(
    {'addr.city.code':'1002'}
)
print(list(result))
上一篇 下一篇

猜你喜欢

热点阅读