今天学了一些关于mongo的知识,在这里分享下一些个人见解
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案,它也是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。
首先,如果要安装mongodb的话 因为我用的是ubuntu,所以打开terminal ,之后输入sudo apt-get install mongodb之后就可以安装mongodb了
安装好后在terminal中输入mongo命令如果出现以下界面就说明连接成功
terminal中可以对mongo做以下操作:
mongo 连接mongo
sudo service mongo start 开启mongo服务
sudo service mongo stop 关闭mongo服务
sudo service mongo restart重启mongo服务
之后在mongo中可以使用以下命令来进行具体的操作
show dbs 可以用来显示已有的数据库
show collections;显示已有的文档集合
use dbname; 使用dbname表示的数据库
db.createCollection(“first_collection”, {“name”: “mongo”,”age”:19});创建名为first_collection文档集合
db.hello.insert({“name”:”mongo”});以插入的形式新建一个表
mongo插入记录
db.first_collection.insert({“key”:”value”});
mongo查找记录
db.first_collection.find().pretty();查找文档中所有内容,pretty()函数会将文档集合中的文档换行显示,比较适合观看
db.first_collection.find({“key”:”value”})特定查找,查找文档中”key”建对应值为”value”的记录
在mongo中比较不是用>,<来表示的
在mongo中,以下符号可以用来比较
gt : 大于 ; lt: 小于 ; gte: 大于等于; lte: 小于等于
db.first_collection.find({“age”:{$lt:20}}).pretty()查找文档中age小于20的记录
文档集合中修改记录
db.first_collection.update(criteria, objNew, upsert, multi)
criteria: update的查询条件, 类似sql update 查询内where 后面的;
objNew: update 的对象和一些更新的操作符等,也可以理解为sql update查询内set后面的
upset: 这个参数的意思是, 如果不存在update的记录, 是否插入objNew, true为插入, 默认是false, 不插入.
Multi: mongodb默认是false, 只更新找到的第一条记录, 如果这个参数为true, 就把按条件查出来多条记录全部更新.
db.first_collection.update({“age”:18},{$set:{“name”:”change”}},false,false)对first_collection中age为18的记录,并将其name对应值改为change,如果没有找到不插入数据,且只更新找到的第一条记录
文档集合中删除记录
db.first_collection.remove({“age”:18});
删除文档集合
db.first_collection.drop();删除对应文档集合
在python中操作mongo首先要安装pymongo
sudo pip install -i http://pypi.douban.com/simple/ pymongo
在python中访问mongo并对其操作的代码如下
#coding=utf-8
from pymongo import *
IP="localhost"
PORT=27017
class MyMongoDB:
'''成员变量'''
client = None ##连接数据库的对象
db = None ## 指定的的数据库
collection = None ## 制定的文档
'''构造函数'''
def __init__(self):
self.client = MongoClient(IP,PORT)
'''构造函数'''
def __init__(self, db, collection):
self.client = MongoClient(IP,PORT)
self.db = self.client[db]
self.collection = self.db[collection]
'''插入一条记录'''
def insert_one(self, dict_record):
try:
self.collection.insert(dict_record)
return 1
except:
return 0
'''插入多条记录'''
def insert_many(self, dict_list):
try:
self.collection.insert_many(dict_list)
return 1
except:
return 0
'''查询记录'''
def query(self, query_regex={}):
result_list = []
for i in self.collection.find(query_regex):
result_list.append(i)
return result_list
'''修改记录'''
def update(self, criteria,ObjNew,upset=False, Multi=False):
self.collection.update(criteria, ObjNew, upset,Multi)
return 1
'''删除记录'''
def remove(self, remove_regex):
self.collection.remove(remove_regex)
def main():
### 初始化
db = 'YUPWEI'
collection = 'YUPWEI'
mongodb = MyMongoDB(db,collection)
# ### 插入一条记录
dict_record = {'name':'test','age':22}
print mongodb.insert_one(dict_record)
# ### 修改记录
criteria = {'age':22}
objNew = {'$set':{'name':'test_change'}}
mongodb.update(criteria,objNew)
### 删除记录
remove_regex = {'age':22}
mongodb.remove(remove_regex)
### 查询记录
query_list = mongodb.query()
for i in query_list:
print i
if __name__ == '__main__':
main()