MongoDB 常用记录

隔了小半年,因为输出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都取出来了

添加新评论