MongoDB
##环境Ubuntu
安装MongoDB
sudo apt-get update sudo apt-get install mongodb
启动服务
mongod
启动客户端
mongo
##客户端常用命令
查看有数据库列表
show dbs;
选着使用数据库
use mydb;#如果没有这个数据库,mongo会在插入数据的时候默认创建
查看这个数据库中的collections
show collections;
上面1,2,3几步是基本和mysql的思路是一样的;
创建collection
data = {"a":1, "b":2}# 在Mongo中这种都叫documnt, db.mycol.insert(data)
如果在mydb中
没有
mycol这个collection,在执行这条插入的时候,就自动生成mycol
;还有就是db
是不是指自己的数据库;查询collection中的document(就把他当做记录吧)
db.mycol.findOne();# 查询一个 db.mycol.find(); # 全部查询 db.mycol.find({"a":1, "b":2 ...}) # 条件查询
修改document
db.mycol.update({查询条件},{查询后需要改的字段}, false/true, false/true) //db.collection.update( <query>, <update>, <upsert>, <multi> ) query: 查询条件 如:{"a":1} update: 查询出来后的需要修改的字段 如: {"a", 2} upsert: 如果查询不出来,是否直接把update中的值插入到collection中, 默认false multi: 是否批量修改, 默认false
例子:
#没有就插入一条 db.col.update({"a":1},{"a":"upsert data"}, true, false) #把所有的都改了,发现有错 db.col.update({},{"a":"upsert data"}, true, true) # 修改错误提示: multi update only works with $ operators, 加一个$set db.col.update({},{'$set':{"a":"22"}}, false, {"multi":true})
删除document
db.collection.remove({}, justOne)# justOne: boolen, true/false #默认删除所有all, 所以要小心啊 db.col.remove() #
删除整个collection
db.mycol.drop()
删除整个数据库
use mydb; db.dropDatabase();
其他
查看当前在使用的数据库:
db
好了,以上都是最常用的,其他的高级技能,以后有空在写,写这一个入门命令,主要是想写tornado的简单restFull api;
python 连接 mongo
装一个mongo客户端py,这里使用pymongo
easy_installed pymongo
代码示例:
import pymongo conn = pymongo.Connection('localhost', 27017) db = conn.mydb print db.collection_names() for item in db.col_test_1.find(): print item print db.col_test_1.find() print db.col_test_1.find_one()
提示:
当要把mongodb的对象转成json,必须要把objectId 删除了,如:
import json
data = db.col_my.find_one({})
del data['_id']
data = json.dumps(data)
如果你正的想要object_id,就用工具解析一下
from bson import json_util
import json
data = json.dumps(data, default=json_util.default)
这样就可以把Date()类型和id都取出来了