mogodb and pymongo

ubuntu 安装:apt-get  install   mongdb
若需要使用python链接mongodb还需要安装pymogo :pip  install pymongo
1.先尝试下pymongo链接mongodb
>import  pymongo
>con=pymongo.Connection(‘localhost‘,27017)
>db = con.test
>table=db.foo
>table.insert({‘py‘:‘pymongo‘})      #插入一条数据

或者简化点:
table=pymongo.Connection(‘localhost‘,27017).test.foo
table.insert({‘kkk‘:‘kkkk‘,‘pppp‘:‘pppp‘})

2.权限管理常用命令
  use admin   #进入数据库admin
  db.addUser(‘name‘,‘pwd‘)   #增加或修改用户密码
  db.system.users.find()   #查看用户列表
  db.auth(‘name‘,‘pwd‘)   #用户认证    这一个返回1就认证成功了,只有认证成功才能对数据库进行操作
  db.removeUser(‘name‘)  #删除用户
  show users  #查看所有用户
  show dbs   #查看所有数据库  show collections   #查看所有的collection(类似查询表,show tables)
  db.printCollectionStats()   #查看各collection的状态
  db.printReplicationInfo()  #查看主从复制状态
3..链接数据库test
mogodb>use  test  #一般默认就是链接test数据库的,可以不写,链接其他库需要             mogodb>db.foo.insert({data:‘2014-9-21‘})  #向foo集合(表)插入一条数据
mogodb>db.foo.update({a:1},{a:2})  #向foo集合更新一条数据,若没有匹配到{a:1},则增加一条数据{a:2}
mogodb> db.users.update({age: 25}, {$set: {name: ‘changeName‘}}, false, true);
相当于:update users set name = ‘changeName’ where age = 25;
mogodb> db.users.update({name: ‘Lisi‘}, {$inc: {age: 50}}, false, true);
相当于:update users set age = age + 50 where name = ‘Lisi’;
mogodb> db.users.update({name: ‘Lisi‘}, {$inc: {age: 50}, $set: {name: ‘hoho‘}}, false, true);
相当于:update users set age = age + 50, name = ‘hoho’ where name = ‘Lisi’;

mogodb>db.foo.find()  #向foo集合(表)查询条数据;
mogodb>db.foo.findOne()  #向foo集合(表)查询条数据,jons显示
mogodb>db.foo.remove({a:1})   #向foo集合(表)删除一条数据
mogodb>db.foo.remove()   #向foo集合(表)删除所有数据
----------------
use kkk         #链接数据库kkk,插入数据库后,就会自动创建数据库kkk
db.tables.insert({})   #创建集合(表)tables,并插入数据;如集合存在测插入空数据
db.tables.save({})#创建集合(表)tables,并保存数据;如集合存在测新增空数据并保存
db.tables.drop()    #删除oo集合(表)
db.getName()   #获取当前使用的数据库名称1
db   #获取当前使用的数据库名称2
db.dropDatabase() #删除当前使用的数据库
db.repairDatabase();#修复当前使用的数据库
db.cloneDatabase(“127.0.0.1”);   #从指定机器克隆数据库
db.copyDatabase("mydb", "temp", "127.0.0.1");  #从指定机器复制指定数据库到某库
db.getMongo();  获取链接db的机器地址
 

         


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。