隔了小半年,因为输出json, Eve 这个框架使用了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的简单RESTful 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都取出来了