Login
网站首页 > 文章中心 > 其它

关于mongodbphplike的信息

作者:小编 更新时间:2023-09-17 19:47:03 浏览量:156人看过

如何用php对mongodb进行模糊查询

土嘎嘎的粉丝们大家好,试试这个 $mongo_db-like('name','维达'); 如果我的回答没能帮助您,请继续追问. 您也可以向我们团队发出请求,会有更专业的人来为您解答.

mongodb 请问php中的这句mysql语法,在mongodb中如何写.

查询:

MySQL:

SELECT * FROM user

Mongo:

db.user.find()

SELECT * FROM user WHERE name = 'starlee'

db.user.find({'name' : 'starlee'})

插入:

如果你想在MySQL里添加一个字段,你必须:

ALTER TABLE user....

但在MongoDB里你只需要:

删除:

DELETE * FROM user

db.user.remove({})

$gt : ; $gte : = ; $lt : ; $lte : = ; $ne : !=

更新:

SELECT COUNT(*) FROM user WHERE ◆name◆ = 'starlee'

db.user.find({'name' : 'starlee'}).count()

SELECT * FROM user ORDER BY age DESC

db.user.find().sort({'age' : -1})

SELECT name, sum(marks) FROM user GROUP BY name

db.user.group({

key : {'name' : true},

cond: {'name' : 'foo'},

reduce: function(obj,prev) { prev.msum ◆= obj.marks; },

initial: {msum : 0}

});

发现很多人在搜MongoDB循环插入数据,下面把MongoDB循环插入数据的方法添加在下面:

for(var i=0;i100;i◆◆)db.test.insert({uid:i,uname:'nosqlfan'◆i});

上面一次性插入一百条数据,大概结构如下:

简易对照表

SQL Statement Mongo Query Language Statement

CREATE TABLE USERS (a Number, b Number) implicit; can be done explicitly

INSERT INTO USERS VALUES(1,1) db.users.insert({a:1,b:1})

SELECT a,b FROM users db.users.find({}, {a:1,b:1})

SELECT * FROM users db.users.find()

SELECT * FROM users WHERE name LIKE "%Joe%" db.users.find({name:/Joe/})

SELECT * FROM users WHERE name LIKE "Joe%" db.users.find({name:/^Joe/})

SELECT * FROM users ORDER BY name DESC db.users.find().sort({name:-1})

CREATE INDEX myindexname ON users(name) db.users.ensureIndex({name:1})

CREATE INDEX myindexname ON users(name,ts DESC) db.users.ensureIndex({name:1,ts:-1})

SELECT * FROM users WHERE a=1 and b='q' db.users.find({a:1,b:'q'})

SELECT * FROM users LIMIT 1 db.users.findOne()

SELECT DISTINCT last_name FROM users db.users.distinct('last_name')

SELECT COUNT(*y) FROM users db.users.count()

SELECT COUNT(AGE) from users db.users.find({age: {'$exists': true}}).count()

UPDATE users SET a=1 WHERE b='q' db.users.update({b:'q'}, {$set:{a:1}}, false, true)

DELETE FROM users WHERE z="abc" db.users.remove({z:'abc'});

###################################################

第一段:操作符

操作符相信大家肯定都知道了,就是等于、大于、小于、不等于、大于等于、小于等于,但是在mongodb里不能直接使用这些操作符.在mongodb里的操作符是这样表示的:

(1) $gt (大于)

(10) $set就是相当于sql的set field = value

(11) $unset就是删除字段

第二段:CURD 增、改、读、删

增加

复制代码代码如下:

db.collection-insert({'name' = 'caleng', 'email' = 'admin#admin.com'});

是不是灰常简单呀,对就是这么简单,它没有字段的限制,你可以随意起名,并插入数据

查询

db.collection.find(array('name' = 'bailing'), array('email'='email@qq.com'))

db.collection.findOne(array('name' = 'bailing'), array('email''email@qq.com'))

大家可以看到查询我用了两种不同的写法,这是为什么,其实这跟做菜是一样的,放不同的调料,炒出的菜是不同的味道.下面给大家说一下,这两种调料的不同作用.

findOne()只返回一个文档对象,find()返回一个集合列表.

也就是说比如,我们只想查某一条特定数据的详细信息的话,我们就可以用findOne();

如果想查询某一组信息,比如说一个新闻列表的时候,我们就可以作用find();

那么我想大家这时一定会想到我想对这一个列表排序呢,no problem mongodb会为您全心全意服务

db.collection.find().sort({age:1}); //按照age正序排列

db.collection.find().sort({age:-1}); //按照age倒序排列

db.collection.count(); //得到数据总数

db.collection.limit(1); //取数据的开始位置

db.collection.skip(10); //取数据的结束位置

//这样我们就实现了一个取10条数据,并排序的操作.

删除

删除有两个操作 remove()和drop()

db.collection.remove({"name",'jerry'}) //删除特定数据

db.collection.drop() //删除集合内的所有数据

distinct操作

数据库操作语法

mongo --path

db.AddUser(username,password) 添加用户

db.auth(usrename,password) 设置数据库连接验证

db.cloneDataBase(fromhost) 从目标服务器克隆一个数据库

db.commandHelp(name) returns the help for the command

db.copyDatabase(fromdb,todb,fromhost) 复制数据库fromdb---源数据库名称,todb---目标数据库名称,fromhost---源数据库服务器地址

db.currentOp() 取消当前库的当前操作

db.dropDataBase() 删除当前数据库

db.eval(func,args) run code server-side

db.getCollection(cname) 取得一个数据集合,同用法:db['cname'] or db.cname

db.getCollenctionNames() 取得所有数据集合的名称列表

db.getLastError() 返回最后一个错误的提示消息

db.getLastErrorObj() 返回最后一个错误的对象

db.getMongo() 取得当前服务器的连接对象get the server connection object

db.getMondo().setSlaveOk() allow this connection to read from then nonmaster membr of a replica pair

db.getName() 返回当操作数据库的名称

db.getPrevError() 返回上一个错误对象

db.getProfilingLevel() ?什么等级

db.getReplicationInfo() ?什么信息

db.getSisterDB(name) get the db at the same server as this onew

db.killOp() 停止(杀死)在当前库的当前操作

db.printCollectionStats() 返回当前库的数据集状态

db.printReplicationInfo()

db.printSlaveReplicationInfo()

db.printShardingStatus() 返回当前数据库是否为共享数据库

db.removeUser(username) 删除用户

db.repairDatabase() 修复当前数据库

db.resetError()

db.runCommand(cmdObj) run a database command. if cmdObj is a string, turns it into {cmdObj:1}

db.shutdownServer() 关闭当前服务程序

db.version() 返回当前程序的版本信息

数据集(表)操作语法

db.linlin.find({id:10}) 返回linlin数据集ID=10的数据集

db.linlin.find({id:10}).count() 返回linlin数据集ID=10的数据总数

db.linlin.find({id:10}).sort() 返回linlin数据集ID=10的排序数据集

db.linlin.findOne([query]) 返回符合条件的一条数据

db.linlin.getDB() 返回此数据集所属的数据库名称

db.linlin.getIndexes() 返回些数据集的索引信息

db.linlin.group({key:...,initial:...,reduce:...[,cond:...]})

db.linlin.mapReduce(mayFunction,reduceFunction,optional params)

db.linlin.remove(query) 在数据集中删除一条数据

db.linlin.renameCollection(newName) 重命名些数据集名称

db.linlin.save(obj) 往数据集中插入一条数据

db.linlin.stats() 返回此数据集的状态

db.linlin.storageSize() 返回此数据集的存储大小

db.linlin.totalIndexSize() 返回此数据集的索引文件大小

db.linlin.totalSize() 返回些数据集的总大小

db.linlin.update(query,object[,upsert_bool]) 在此数据集中更新一条数据

db.linlin.validate() 验证此数据集

db.linlin.getShardVersion() 返回数据集共享版本号

mongodb 中的like 怎么使用

你是指的模糊查询吧,就是sql的select * from table where xx like yy这种的是吧.

你可以使用正则表达式,我以MongoDB自带的shell为例,其它(比如说你用java就参考java的官方文档和API)

db.user.find({"name":/ab/})

这样,可以查出所有包含有"ab"字符串的数据了.等同于select * from user where name like "ab"

更多高级查询你看一下MongoDB的官方文档,关于正则表达式的部分.

以上就是土嘎嘎小编为大家整理的关于mongodbphplike的信息相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!

版权声明:倡导尊重与保护知识产权。未经许可,任何人不得复制、转载、或以其他方式使用本站《原创》内容,违者将追究其法律责任。本站文章内容,部分图片来源于网络,如有侵权,请联系我们修改或者删除处理。

编辑推荐

热门文章