Mongodb数据库操作
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"
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}})
db.test.ensureIndex({"name":1})
//去掉字段email,
//alter table test drop email
db.test.update({},{$unset:{"email":""}},{multi:true})
//查看表索引
db.test.getIndexes()
//修改collections名
db.test.renameCollection("newtablename")
//导出数据
//导出csv格式
mongoexport -d dbname -c tablename -u test -p test -f "fieldname" -csv -o "c:/db.csv"
//往数据表news中导入数据,用户名为test
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"}})
//位置更新
db.test.update({"sn" : "1","stock.fnfp.pn":"aa"} , {$push : { "stock.$.fnfp": {"price":"555"}}})
//往name="joe"的这些记录里添加内容atta.d = "ddd"
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)})
结果
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的记录
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
db.test.update({"sn":1},{$pop:{"price":0}})
移除price数组下的第0项
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);
}
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")
use admin
db.createRole({role:'sysadmin',roles:[],privileges:[{resource:{anyResource:true},actions:'anyAction']}]})
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数据库操作的更多相关文章
- mongoDB 数据库操作
mongoDB 数据库操作 数据库命名规则 . 使用 utf8 字符,默认所有字符为 utf8 . 不能含有空格 . / \ "\0" 字符 (c++ 中会将 "\0&q ...
- mongodb 数据库操作--备份 还原 导出 导入(转)
mongodb 数据库操作--备份 还原 导出 导入 -------------------MongoDB数据导入与导出------------------- 1.导出工具:mongoexport ...
- node.js零基础详细教程(6):mongodb数据库操作
第六章 建议学习时间4小时 课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...
- node.js零基础详细教程(6):mongodb数据库操作 以及导入导出
第六章 建议学习时间4小时 课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...
- mongodb 数据库操作 -- 》常用命令
首先需要下载数据库,安装后,找到bin目录,点开bin目录,复制当前路径配置到环境变量中 和bin的同级下,需要建立一个data/db文件夹,该文件夹并不会自动生成,必须手动设置 启动数据库 看 ...
- mongodb数据库操作 python+命令行
一.python操作 from bson.objectid import ObjectId import pymongo client1 = pymongo.MongoClient(host=) ...
- mongodb 数据库操作--备份 还原 导出 导入
mongodb数据备份和还原主要分为二种,一种是针对于库的mongodump和mongorestore,一种是针对库中表的mongoexport和mongoimport 一,mongodump备份数据 ...
- MongoDB (五) MongoDB 数据库操作
一.MongoDB创建数据库: use 命令 MongoDB use DATABASE_NAME 用于创建数据库.该命令将创建一个新的数据库,如果它不存在,否则将返回现有的数据库. 语法: use D ...
- mongodb数据库操作--备份 还原 导出 导入
首先数据库备份: mongodump -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -o 文件存在路径 mongodump -h 127.0.0.1 -u admin -p ...
随机推荐
- LeetCode之“动态规划”:Scramble String
题目链接 题目要求: Given a string s1, we may represent it as a binary tree by partitioning it to two non-emp ...
- mac os 中如何修改顶栏图标的顺序
很简单哦! 按住 cmd键同时鼠标选中那个图标,直接拖到你想要的位置即可.
- JSP 分页显示数据 (Oracle)
要实现分页,首先我们要做的就是如何来编写SQL语句,网上也有很多,大家可以搜一下.在这里,我们使用一种比较常用的方式来编写SQL语句.代码如下: ----分页显示 select * from (sel ...
- 我的.net并发系列文章及项目经验整理
一直在关注研究.net下的并发处理,之前也发布过几篇文章,今天就都整理下. 使用BlockingCollection来做并发处理,同时增加并发队列来做并发处理时的退出判断: 你真的知道.NET Fra ...
- 经典的java中return和finally问题!
经典的java中return和finally问题! 标签: 杂谈 分类: java学习 前一段时间 参加公司的笔试问了这个问题,回来一查才知道当时自己做错了,百思不得其解,上网查到下面的程序,但是运行 ...
- SpringMvc+AngularJS通过CORS实现跨域方案
什么是跨域请求问题? 这个问题的起因在于现代浏览器默认都会基于安全原因而阻止跨域的ajax请求,这是现代浏览器中必备的功能,但是往往给开发带来不便. 但跨域的需求却一直都在,为了跨域,勤劳勇敢的程序猿 ...
- 没人看系列----css 随笔
目录 没人看系列----css 随笔 没人看系列----html随笔 前言 没什么要说的就是自己总结,学习用的如果想学点什么东西,请绕行. CSS (Cascading Style Sheets)层叠 ...
- Ubuntu12.04下Django1.4的删除目录
网上有很多文章说这个问题,大意就是下载压缩包以后用 sudo python setup.py install 上面这条命令安装的Django,然后到相关目录下把那个Django的目录删掉就Ok了,但是 ...
- Application "org.eclipse.ui.ide.workbench" could not be found in the registry.问题的解决
今天升级Eclipse,升级完Restart,碰到启动不了让看日志,日志里主要错误信息即是Application "org.eclipse.ui.ide.workbench" co ...
- Android Gradle使用总结
转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/77678577 本文出自[赵彦军的博客] 其他 Groovy 使用完全解析 http ...