mysql/mongodb对比

CREATE TABLE USERS (a Number, b Number)
Implicit or use MongoDB::createCollection().
INSERT INTO USERS VALUES(1,1)
$db->users->insert(array("a" => 1, "b" => 1));
SELECT a,b FROM users
$db->users->find(array(), array("a" => 1, "b" => 1));
SELECT * FROM users WHERE age=33
$db->users->find(array("age" => 33));
SELECT a,b FROM users WHERE age=33
$db->users->find(array("age" => 33), array("a" => 1, "b" => 1));
SELECT a,b FROM users WHERE age=33
$db->users->find(array("age" => 33), array("a" => 1, "b" => 1));
SELECT a,b FROM users WHERE age=33 ORDER BY name
$db->users->find(array("age" => 33), array("a" => 1, "b" => 1))->sort(array("name" => 1));
SELECT * FROM users WHERE age>33
$db->users->find(array("age" => array('$gt' => 33)));
SELECT * FROM users WHERE age<33
$db->users->find(array("age" => array('$lt' => 33)));
SELECT * FROM users WHERE name LIKE "%Joe%"
$db->users->find(array("name" => new MongoRegex("/Joe/")));
SELECT * FROM users WHERE name LIKE "Joe%"
$db->users->find(array("name" => new MongoRegex("/^Joe/")));
SELECT * FROM users WHERE age>33 AND age<=40
$db->users->find(array("age" => array('$gt' => 33, '$lte' => 40)));
SELECT * FROM users ORDER BY name DESC
$db->users->find()->sort(array("name" => -1));
CREATE INDEX myindexname ON users(name)
$db->users->ensureIndex(array("name" => 1));
CREATE INDEX myindexname ON users(name,ts DESC)
$db->users->ensureIndex(array("name" => 1, "ts" => -1));
SELECT * FROM users WHERE a=1 and b='q'
$db->users->find(array("a" => 1, "b" => "q"));
SELECT * FROM users LIMIT 10 SKIP 20
$db->users->find()->limit(10)->skip(20);
SELECT * FROM users WHERE a=1 or b=2
$db->users->find(array('$or' => array(array("a" => 1), array("b" => 2))));
SELECT * FROM users LIMIT 1
$db->users->find()->limit(1);
EXPLAIN SELECT * FROM users WHERE z=3
$db->users->find(array("z" => 3))->explain()
SELECT DISTINCT last_name FROM users
$db->command(array("distinct" => "users", "key" => "last_name"));
SELECT COUNT(*y) FROM users
$db->users->count();
SELECT COUNT(*y) FROM users where AGE > 30
$db->users->find(array("age" => array('$gt' => 30)))->count();
SELECT COUNT(AGE) from users
$db->users->find(array("age" => array('$exists' => true)))->count();
UPDATE users SET a=1 WHERE b='q'
$db->users->update(array("b" => "q"), array('$set' => array("a" => 1)));
UPDATE users SET a=a+2 WHERE b='q'
$db->users->update(array("b" => "q"), array('$inc => array("a" => 2)));
DELETE FROM users WHERE z="abc"
$db->users->remove(array("z" => "abc"));

sc.exe create MongoDB30 binPath= "d:\mongodb30\bin\mongod.exe -auth --logpath D:\mongodb\log\MongoDB.log --logappend --dbpath d:\mongodb\data --service " DisplayName= "MongoDB30" start= "auto"
 
//select * from test where name='joe'
db.test.find({"name":"joe"})

//不区分大小写的查询

db.test.find({"name":{"$regex":"WILLIAM","$options":"i"}})  

//select * from test where name='joe' limit 20

db.test.find({"name":"joe"}).limit(20)

//类似mysql select * from test where name='joe' limit 20,20

db.test.find({"name":"joe"}).limit(20).skip(20)

//select * from test where name like '%william%' 不含有

  • db.test.find({"name":/.*william.*/i})
  • //不含有
  • db.test.find({"name":{$not:/.*william.*/i}})
 //建立索引在字段name上,1(ascending),-1(descending)
db.test.ensureIndex({"name":1})

//去掉字段email,

//alter table test drop email

//multi:true 参数可省略,省略的意思是只删除第一行的email字段,multi:true代表删除全部行的email字段
db.test.update({},{$unset:{"email":""}},{multi:true})

//查看表索引

//show index from test
db.test.getIndexes()

//修改collections名

db.test.renameCollection("newtablename")

//导出数据

//mysqldump -u test dbname tablename -p > "c:/db.sql"
mongoexport -d dbname -c tablename -u test -p -o "c:/db.json"
 

//导出csv格式

mongoexport -d dbname -c tablename -u test -p test -f "fieldname" -csv -o "c:/db.csv"

//往数据表news中导入数据,用户名为test

//mysql -u test -D test -p < "c:/db.sql"
mongoimport -d test -c news -u test -p password "c:/db.json" 

//找出name="joe"的记录中,该行是否含有atta.b这个字段

db.test.find({"name":"joe","atta.b":{$exists:true}}).count()

//找出name="joe"并且atta.b = "bbb"的记录

db.test.find({"name":"joe","atta.b":"bbb"}  

//删除name='williamf'这条记录中的Email项为"aa@qq.com"的数值

db.test.update({"name":"william"},{"$pull":{"email":"aa@qq.com"}})

//位置更新

//找到sn等于1的这条记录,找到stock.fnfp.pn等于"aa"这个位置,加入数据:"price":"555"
//前提是stock.fnfp为array类型
db.test.update({"sn" : "1","stock.fnfp.pn":"aa"} , {$push : { "stock.$.fnfp": {"price":"555"}}})

//往name="joe"的这些记录里添加内容atta.d = "ddd"

//前提是atta为array类型
db.test.update({"name":"joe"},{$push:{"atta":{"d":"ddd"}}})

//update test set email='a.163.com' where name='joe'

db.test.update({"name":"joe"},{$set:{"email":"a.163.com"}})

//查询所有name字段是字符类型的

db.test.find({name: {$type: 2}})

//查询所有age字段是整型的

db.test.find({age: {$type: 16}})

//查询以字母b或者B带头的所有记录

db.users.find({name: /^b.*/i})

//查询 age > 18 的记录,以下查询都一样

db.users.find({age: {$gt: 18}})
db.users.find({$where: "this.age > 18"})
db.users.find("this.age > 18")
f = function() {return this.age > 18} db.users.find(f)

//返回3条记录并打印信息

db.users.find().limit(3).forEach(function(user) {print('my age is ' + user.age)})

结果

my age is 18
my age is 19
my age is 20
 
//复制news表数据到另一个表news_bak
//前提是news_bak为空表,或者两个表的_id不重复
db.news.find().forEach(function(x){db.news_bak.insert(x)})

//显示你所有当前正在运行操作

db.currentOp()

//可以用来杀掉长查询

db.killOp(opid)

//显示你整个服务器的状态,对监控非常有用

db.serverStatus()

//显示你选中库的状态

db.stats()

//特定集的状态

db.collection.stats()

//查看collection数据的大小

db.collection.dataSize()

//查询所有索引的大小

db.collection.totalIndexSize()

// 修改密码

db.changeUserPassword("reporting", "SOh3TbYhxuLiW8ypJPxmt1oOfL")

//删除字段中的某个值,该字段必须为array

{
"name":"joe"
"email":
[
"aaa@163.com",
{"qqemail": "aa@qq.com"}
]
}
db.test.update({"name":"joe"},{$pull:{"email":"aaa@163.com"}})

或者:

db.test.update({"name":"joe"},{$pull:{"email":{"qqemail":"aa@qq.com"}}})

upsert
db.post.update({count:100},{"$inc":{count:10}},true)

在找不到count=100这条记录的时候,自动插入一条count=100,然后再加10,最后得到一条 count=110的记录

 //备份数据库dbname,bin下生成一个dbname.bak/dbname的目录
mongodump -h 127.0.0.1 -d dbname -u username -p -o d:/dbname.bak

//还原数据库dbname

mongorestore -h 127.0.0.1 -d dbname -u username -p password dbname.bak/dbname

//删除复杂的嵌套文档

db.test.find()

{
"_id":ObjectId("52428f5d5ab08c5e801f7209"),
"price":[
{"digk":{"nt1":1,"nt2":2}},
{"avn":{"nt1":22,"nt2":23}}
],
"sn":1
}

用javascript来执行mongodb

//删除字段price下的avn
方法一:

db.test.update({"sn":1},{$pop:{"price":0}}) 

移除price数组下的第0项

缺陷必须知道avn在price中的位置
 
方法三:

db.test.update({"sn":1},{$pull:{"price":{"avn":{"nt1":22,"nt2":23}}}})

缺陷必须知道price中的avn的

 
方法二:
var cursor=db.test.find();
while(cursor.hasNext()){
var y=cursor.next();
for(var i=0;i<y.price.length;i++){
delete y.price[i].avn;
}
db.test.save(y);
}
//给现有collections新增自增ID,字段名:sn
var cursor=db.test.find();
var i = 1;
while(cursor.hasNext()){
var y=cursor.next();
var _id = y._id;
db.test.update({"_id":_id},{$set:{"sn":i}});
i++;
}

// demo 存入如下文档

db.test.save({"sn":1,
"contact":
{
"China":[
{"city":"beijing","email":"a@163.com","tel":"010-6666"},
{"city":"shanghai","email":"b@263.com","tel":"021-8888"},
{"city":"shenzhen","email":"c@sohu.com","tel":"0755-9999"}
],
"United-States":[
{"city":"Newyork","email":"a@163.com","tel":"010-6666"},
{"city":"Washington","email":"a@163.com","tel":"010-6666"}
]
}
}) db.test.save({"sn":2,
"contact":
{
"Japan":[
{"city":"tokyo","email":"a@163.com","tel":"010-6666"},
{"city":"Osaka","email":"b@263.com","tel":"021-8888"},
{"city":"Hokkaido","email":"c@sohu.com","tel":"0755-9999"}
],
"Canada":[
{"city":"Vancouver","email":"a@163.com","tel":"010-6666"},
{"city":"Ottawa","email":"a@163.com","tel":"010-6666"}
]
}
})

--删除China下,city为shenzhen的一组数据

var cursor = db.test.find({"sn":1});
while(cursor.hasNext()){
var y = cursor.next();
for(var i =0;i < y.contact.China.length;i++){
if(y.contact.China[i].city == 'shenzhen'){
delete y.contact.China[i];
}
}
db.test.save(y); }

--将China下city为beijing 的,city改为guangzhou

db.test.update({"sn":1,"contact.China.city":"beijing"},{$set:{"contact.China.$.city":"guangzhou"}})

--重命名collections  ,将usersinfo 重命名为users

db.usersinfo.renameCollection("users")
 // 释放内存
 db.runCommand({closeAllDatabases:1})  //mongodb3.0之后官方放弃了这个功能
 //mongodb 启动设置Mongodb运行内存大小,使之不能无限期吃内存
wireTigerCacheSizeGB=n //n为多少GB
 
//切割释放日志
db.runCommand({logRotate:1}) //windows
kill -SIGUSR1 pid //Linux下,pid是mongodb的进程号
 
//建唯一索引
 db.person.ensureIndex({firstname:1, lastname: 1},{unique: true});
 
//查看索引
 db.data.getIndexes()
mongorestore -d parts -directoryperdb d:\databackup\parts\
 
//使用存储过程
db.system.js.save({_id:"addNumbers",value:function(x,y){return x+y;}})
 
//查看存储过程
db.system.js.find()
 
//执行存储过程
db.eval("addNumbers(3,9);");
 
如果出现验证错误,那么需要对该登录用户进行角色授权:
1、建立sysadmin角色,
use admin
db.createRole({role:'sysadmin',roles:[],privileges:[{resource:{anyResource:true},actions:'anyAction']}]})
2、授权
use test
db.grantRolesToUser("test",[{role:'sysadmin',db:'admin'}]) key:[{'id':123,'value':11},{'id':124,'value':12}]

查询匹配key里id与value皆匹配:find({'key':{$elemMatch:{"id":123,"value":12}}})可以做到返回不出结果。

更多信息尽在QQ群内:607021567

Mongodb数据库操作的更多相关文章

  1. mongoDB 数据库操作

    mongoDB 数据库操作 数据库命名规则 . 使用 utf8 字符,默认所有字符为 utf8 . 不能含有空格 . / \ "\0" 字符 (c++ 中会将 "\0&q ...

  2. mongodb 数据库操作--备份 还原 导出 导入(转)

    mongodb 数据库操作--备份 还原 导出 导入   -------------------MongoDB数据导入与导出------------------- 1.导出工具:mongoexport ...

  3. node.js零基础详细教程(6):mongodb数据库操作

    第六章 建议学习时间4小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...

  4. node.js零基础详细教程(6):mongodb数据库操作 以及导入导出

    第六章 建议学习时间4小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...

  5. mongodb 数据库操作 -- 》常用命令

    首先需要下载数据库,安装后,找到bin目录,点开bin目录,复制当前路径配置到环境变量中 和bin的同级下,需要建立一个data/db文件夹,该文件夹并不会自动生成,必须手动设置   启动数据库  看 ...

  6. mongodb数据库操作 python+命令行

      一.python操作 from bson.objectid import ObjectId import pymongo client1 = pymongo.MongoClient(host=) ...

  7. mongodb 数据库操作--备份 还原 导出 导入

    mongodb数据备份和还原主要分为二种,一种是针对于库的mongodump和mongorestore,一种是针对库中表的mongoexport和mongoimport 一,mongodump备份数据 ...

  8. MongoDB (五) MongoDB 数据库操作

    一.MongoDB创建数据库: use 命令 MongoDB use DATABASE_NAME 用于创建数据库.该命令将创建一个新的数据库,如果它不存在,否则将返回现有的数据库. 语法: use D ...

  9. mongodb数据库操作--备份 还原 导出 导入

    首先数据库备份: mongodump -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -o 文件存在路径  mongodump -h 127.0.0.1 -u admin -p ...

随机推荐

  1. LeetCode之“字符串”:Valid Palindrome

    题目链接 题目要求: Given a string, determine if it is a palindrome, considering only alphanumeric characters ...

  2. redis删除所有key

    flushdb 删除当前数据库的所有keyflushall  删除所有数据库的所有keydbsize   返回当前数据库的key的数量

  3. ES6中Promise详解

    Promise,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果.从语法上说,Promise 是一个对象,从它可以获取异步操作的消息. Promise 提供统一的 AP ...

  4. remove Nth Node from linked list从链表中删除倒数第n个元素

    Given a linked list, remove the nth node from the end of list and return its head. For example, Give ...

  5. 学习MQ(二)基本概念

    学习MQ(二)基本概念 这次简单罗列一下MQ的基本概念,还有我对它们的理解 1.queue manager 队列管理器,这是MQ系统中最上层的一个概念.每一个queue manager都有一个侦听器, ...

  6. IntelliJ IDEA下Cannot resolve symbol XXX的解决方法

    Idea导入maven项目后,运行能通过,但是打开一些类后,会出现Cannot resolve symbol XXX的错误提示. 考虑几种可能: 1.JDK版本,设置JDK和Maven的JDK版本. ...

  7. Nginx Rewrite详解

    Nginx Rewrite详解 引用链接:http://blog.cafeneko.info/2010/10/nginx_rewrite_note/ 原文如下: 在新主机的迁移过程中,最大的困难就是W ...

  8. ROS:使用Qt Creator创建GUI程序(一)

    开发环境: Ubuntu14.04 ROS indigo version Qt Creator 3.0.1 based on Qt 5.2.1 步骤如下:(按照下面命令一步步来,亲测可行) (一)安装 ...

  9. 【读书笔记】C++Primer---第二章

    1.C++基本数据类型:字符型.整型.浮点型等: 2.算术类型如下表,下表只是表示C++要求的最小储存空间,但是一般编译器使用的都比所要求的储存空间大,以前类型所能表示的最大值也因机器的不同而有不同的 ...

  10. EF Linq中的左连接Left Join查询

    linq中的join是inner join内连接,就是当两个表中有一个表对应的数据没有的时候那个关联就不成立. 比如表A B的数据如下 from a in A join b in B on a.BId ...