MongoDB数据库及其Python用法
一 、命令行模式
mongo # 进入mongodb命令行模式
show dbs
use taobao # 进入该数据库,如不存在则创建之
show tables # 条件操作符
(>) 大于 - $gt # greater than
(<) 小于 - $lt # less than
(>=) 大于等于 - $gte # e equal
(<= ) 小于等于 - $lte
# 查询
db.product.find().pretty().limit().skip().sort({'price':}) # pretty()以易读的方式,limit()限制个数,skip()跳过前12个记录查找,sort()排序,1为升序,-1为降序
db.product.findOne() # 查找一条记录,此时不能带pretty()
db.col.find({"by":"菜鸟教程", "title":"MongoDB 教程"}).pretty() # and
db.col.find({$or:[{"by":"菜鸟教程"},{"title": "MongoDB 教程"}]}).pretty() # or
db.col.find({"likes": {$gt:}, $or: [{"by": "菜鸟教程"},{"title": "MongoDB 教程"}]}).pretty() # and 与 or一起用 # 插入
db.person.insert({'name':'老王'}) 插入数据,如果表person不存在,则会自动创建它再插入。
db.person.drop() # 删除表,如果数据库中只有这一张表,那么数据库也会删除。
# 更新
db.person.update({'name':'kris'},{$set:{'name':'chau'}})
db.person.update({'contry':'china'},{$set:{'class':'five','name':'Low'}},{upsert:true})
db.collection.update(
<query>, # 查找条件
<update>, # 更新内容
{ # 此括号内可选
upsert: <boolean>, # 如果更新内容在记录中不存在,是否插入,默认False
multi: <boolean>, # 默认false,只更新找到的第一条记录,否则更新所有找到的记录
writeConcern: <document> # error 级别
}
)
# 删除
use datatry
db.dropDatabase() # 进入后再执行可删除数据库。 db.person.remove({'name':'chau'})
db.collection.remove(
<query>, # 条件
{
justOne: <boolean>, # 如果为true或1,则只删除第一条
writeConcern: <document> # 抛出异常级别
}
)
# 聚合管道
db.product.aggregate(
[
{$match:{m_id:,mark_time:{$gt:new Date(,,)}}},
{$group: {
_id: {$dayOfMonth:'$mark_time'},
pv: {$sum: }
}
},
{$sort: {"_id": }}
])
二、Python用法
import pymongo
# 连接数据库
client = pymongo.MongoClient('localhost',27017)
db = client['taobao']
# 查找
datas = db['product'].find_one()
datas = db['product'].find({'name':'kris'}).skip(2).limit(n)
# 插入
db['person'].insert({'hello':'you are beautiful'}) # insert不用遍历,效率高
person.insert_many(new_posts) # 插入多条
db['person'].save({'hello':'you are beautiful'}) # save需要遍历列表,一个个插入
# 更新
# update,$set:更新操作,multi=True:是否对查询到的全部数据进行操作,upsert=True:如果找不到查询的结果是否插入一条数据
db.user.update_one({"age":"2"},{"$set":{"name":"qian","age":2}})
db.user.update({"name":"sun"},{"$set":{"name":"qian"}},upsert=True)
# *update_one也是只能对一条数据进行操作,$set是update操作的$操作符,也可以用$inc或$push,前两个操作速度差不多,$push操作速度较慢。
person.update({'name':'kris'}, {'$set':{'class':4}})
# 删除
person.remove({'$or':[{'author':'Mike'},{'author':'Eliot'}]})
或者写成类方法调用
class MyMongoDB(object):
def __init__(self):
try:
self.conn = pymongo.MongoClient(settings["ip"], settings["port"])
except Exception as e:
print(e)
self.db = self.conn[settings["db_name"]]
self.table = self.db[settings["table_name"]] def insert(self,dic):
print("insert...")
self.table.insert(dic) def update(self,dic,newdic):
print("update...")
self.table.update(dic,newdic) def delete(self,dic):
print("delete...")
self.table.remove(dic) def dbfind(self,*dic):
print("find...")
data = self.table.find(*dic)
return data
MongoDB数据库及其Python用法的更多相关文章
- 第一篇:一天学会MongoDB数据库之Python操作
本文仅仅学习使用,转自:https://www.cnblogs.com/suoning/p/6759367.html#3682005 里面新增了如果用用Python代码进行增删改查 什么是MongoD ...
- mongodb数据库操作 python+命令行
一.python操作 from bson.objectid import ObjectId import pymongo client1 = pymongo.MongoClient(host=) ...
- 8.3 操作MongoDB数据库
一项权威调查显示,在大数据时代软件开发人员必备的十项技能中MongoDB数据库名列第二,仅次于HTML5.MongoDB是一个基于分布式文件存储的文档数据库,可以说是非关系型(Not Only SQL ...
- Python 操作 mongodb 数据库
原文地址:https://serholiu.com/python-mongodb 这几天在学习Python Web开发,于 是做准备做一个博客来练练手,当然,只是练手的,博客界有WordPress这样 ...
- Python全栈 MongoDB 数据库(聚合、二进制、GridFS、pymongo模块)
断网了2天 今天补上 聚合操作: 对文档的信息进行整理统计的操作 返回:统计后的文档集合 db.collection.aggregate() 功能:聚合函数,完成聚合操作 参数:聚合条件,配 ...
- Python全栈 MongoDB 数据库(概念、安装、创建数据)
什么是关系型数据库? 是建立在关系数据库模型基础上的数据库,借助于集合代数等概念和方法来处理数据库中的数据, 同时也是一个被组织成一组拥有正式描述性的表格( ...
- Python Json分别存入Mysql、MongoDB数据库,使用Xlwings库转成Excel表格
将电影数据 data.json 数据通过xlwings库转换成excel表格,存入mysql,mongodb数据库中.python基础语法.xlwings库.mysql库.pymongo库.mongo ...
- python操作mongodb数据库
一.MongoDB 数据库操作 连接数据库 import pymongo conn = pymongo.Connection() # 连接本机数据库 conn = pymongo.Connection ...
- python 操作mongodb数据库模糊查询
# -*- coding: utf-8 -*-import pymongoimport refrom pymongo import MongoClient #创建连接#10.20.66.106clie ...
随机推荐
- Java动态代理(二)CGLIB动态代理应用
JDK自从1.3版本开始,就引入了动态代理,JDK的动态代理用起来非常简单,但是它有一个限制,就是使用动态代理的对象必须实现一个或多个接口 .如果想代理没有实现接口的类可以使用CGLIB包. CGLI ...
- [label][Google-Developers] Your First Multi Screen Site
内容是任何网站最重要的部分. 所以,让我们为内容而设计,而不要让设计支配内容. 1. 首先确定我们需要的内容: 2. 基于这个内容,为无论宽.窄的 viewport 创建一个页面结构: 3. 然后在简 ...
- ARPG游戏打击感相关的技术简单总结
说好的技术总结,根据近期的工作总结一下体现游戏打击感相关的技术.一般arpg的游戏打击感除了场景的氛围的烘托,策划的数值:连击,奖励伤害数字的连贯积累反馈,硬直加物理击飞ragdoll,更不可忽视的也 ...
- MySQL 笔记整理(20) --幻读是什么,幻读有什么问题?
笔记记录自林晓斌(丁奇)老师的<MySQL实战45讲> (本篇内图片均来自丁奇老师的讲解,如有侵权,请联系我删除) 20) --幻读是什么,幻读有什么问题? 我们先来看看表结构和初始化数据 ...
- daylyknowledge1
1.数据库截取字符串:toFixed():四舍五入substring(cp_introduce,0,11) cp_introduce前台截取: field: 'an_content', title: ...
- driver.get()和driver.navigate().to()到底有什么不同?-----Selenium快速入门(四)
大家都知道,这两个方法都是跳转到指定的url地址,那么这两个方法有什么不同呢?遇到这种情况,第一反应就是查查官方的文档. 官方文档的说法是:Load a new web page in the cur ...
- T-Sql之集合
1.知识点 先了解一下集合概念,集合运算(UNION(并).EXCEPT(补).INTERSECT(交))是指表之间的垂直操作.区别联接(CROSS,INNER.OUTER)是指表之间的水平操作,基础 ...
- sql数据库 大小查询
select * from sys.master_files where name='CODA_PRD_Catalog' 12416*8/1024=(m)
- java.lang.NoSuchMethodError: javax.servlet.ServletContext.getContextPath()Ljava/lang/String;
问题描述:在eclipse3.7中启动tomcat6时一直出现这个错误, java.lang.NoSuchMethodError: javax.servlet.ServletContext.getCo ...
- collections模块—— Counter
ounter目的是用来跟踪值出现的次数.它是一个无序的容器类型,以字典的键值对形式存储,其中元素作为key,其计数作为value.计数值可以是任意的Interger(包括0和负数).Counter类和 ...