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: 查询条件 如:{"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 pymongoconn = pymongo.Connection('localhost', 27017)db = conn.mydbprint db.collection_names()for item in db.col_test_1.find(): print itemprint 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都取出来了