- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章mongodb和php的用法详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
Mognodb数据库连接. 。
默认格式 。
1
2
3
|
$m
=
new
Mongo();
//这里采用默认连接本机的27017端口,当然也可以连接远程主机如 192.168.0.4:27017,如果端口是27017,端口可以省略。
|
标准连接 。
1
|
$m
=
new
Mongo(
"mongodb://${username}:${password}@localhost"
);
|
实例:
1
|
$m
=
new
Mongo(
"mongodb://127.0.0.1:27017/admin:admin"
);
|
数据库的用户名和密码都是admin 。
数据库操作 。
插入数据 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
<?php
//这里采用默认连接本机的27017端口,当然你也可以连接远程主机如192.168.0.4:27017
//如果端口是27017,端口可以省略
$m
=
new
Mongo(
"mongodb://127.0.0.1:27017/admin:admin"
);
//选择comedy数据库,如果以前没该数据库会自动创建,也可以用$m->selectDB("comedy");
$db
=
$m
->comedy;
//选择comedy里面的collection集合,相当于RDBMS里面的表,也可以使用
$collection
=
$db
->collection;
$db
->selectCollection(
"collection"
);
/*********添加一个元素**************/
$obj
=
array
(
"title"
=>
"php1"
,
"author"
=>
"Bill Watterson"
);
//将$obj 添加到$collection 集合中
$collection
->insert(
$obj
);
/*********添加另一个元素**************/
$obj
=
array
(
"title"
=>
"huaibei"
,
"online"
=> true);
$collection
->insert(
$obj
);
//$query = array("title" => "huaibei");
$query
=
array
(
"_id"
=>
$obj
[
'_id'
] );
$cursor
=
$collection
->find(
$query
);
//遍历所有集合中的文档
foreach
(
$cursor
as
$obj
) {
echo
$obj
[
"title"
] .
"\n"
;
echo
$obj
[
"_id"
] .
"\n"
;
}
//断开MongoDB连接
$m
->close();
|
带条件的查询 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
mysql: id = 123
mongo:
array
(‘id'=>123)
mysql: name link
'%bar%'
mongo:
array
(‘name
' => new MongoRegex(‘/.*bar.*/i'
))
mysql: where id > 10
mongo:
array
(‘id
' => array(‘$gt'
=> 10))
mysql: where id >= 10
mongo:
array
(‘id
' => array(‘$gte'
=> 10))
mysql: where id < 10
mongo:
array
(‘id
' => array(‘$lt'
=> 10))
mysql: where id <= 10
mongo:
array
(‘id
' => array(‘$lte'
=> 10))
mysql: where id > 1
and
id < 10
mongo:
array
(‘id
' => array(‘$gt'
=> 1,
'$lt'
=> 10))
mysql: where id <> 10
mongo:
array
(‘id
' => array(‘$ne'
=> 10))
mysql: where id in(123)
mongo:
array
(‘id
' => array(‘$in'
=>
array
(1,2,3)))
mysql: where id not in(123)
mongo:
array
(‘id
' => array(‘$nin'
=>
array
(1,2,3)))
mysql: where id = 2
or
id = 9
mongo:
array
(‘id
' => array(‘$or'
=>
array
(
array
(‘id
'=>2),array(‘id'
=>9))))
mysql: order by name asc
mongo:
array
(‘sort
'=>array(‘name'
=>1))
mysql: order by name desc
mongo:
array
(‘sort
'=>array(‘name'
=>-1))
mysql: limit 0,2
mongo:
array
(‘limit
'=>array(‘offset'
=>0,
'rows'
=>2))
mysql: select name,email
mongo:
array
(‘name
','
email')
mysql: select
count
(name)
mongo:
array
(‘
COUNT
')
//注意:COUNT为大写
|
查询时,每个Object插入时都会自动生成一个独特的_id,它相当于RDBMS中的主键,用于查询时非常方便 (_id每一都不同,很像自动增加的id) 。
1
2
3
4
5
6
7
8
9
10
11
|
<?php
$param
=
array
(
"name"
=>
"joe"
);
$collection
->insert(
$param
);
$joe
=
$collection
->findOne(
array
(
"_id"
=>
$param
[
'_id'
]));
print_R(
$joe
);
$m
->close();
|
返回结果:Array ( [_id] => MongoId Object ( [$id] => 4fd30e21870da83416000002 ) [name] => joe ) 。
更改字段值 。
1
2
3
4
5
6
7
|
<?php
$sign
=
array
(
"title"
=>
'php1'
);
$param
=
array
(
"title"
=>
'php1'
,
'author'
=>
'test'
);
$joe
=
$collection
->update(
$sign
,
$param
);
|
删除一个数据库 。
1
|
$m -> dropDB(“comedy”);
|
列出所有可用数据库 。
1
|
$m
->listDBs();
//无返回值
|
创建一个MongoDB对象 。
1
2
3
4
5
|
<?php
$mo
=
new
Mongo();
$db
=
new
MongoDB(
$mo
,
'dbname'
);
//通过创建方式获得一个MongoDB对象
|
删除当前DB 。
1
2
3
4
5
|
<?php
$db
=
$mo
->dbname;
$db
->drop();
|
获得当前数据库名 。
1
2
3
4
5
|
<?php
$db
=
$mo
->dbname;
$db
->_tostring();
|
选择想要的collection
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
//A:
$mo
=
new
Mongo();
$coll
=
$mo
->dbname->collname;
//获得一个collection对象
//B:
$db
=
$mo
->selectDB(
'dbname'
);
$coll
=
$db
->collname;
//C:
$db
=
$mo
->dbname;
$coll
=
$db
->collname;
//D:
$db
=
$mo
->dbname;
$coll
=
$db
->selectCollectoin(
'collname'
);
//获得一个collection对象
|
插入数据(MongoCollection对象 。
1
2
3
4
5
6
7
|
$coll
=
$mo
->db->foo;
$a
=
array
(
'a'
=>
'b'
);
$options
=
array
(
'safe'
=>true);
$rs
=
$coll
->insert(
$a
,
$options
);
|
删除数据库中的记录(MongoCollection对象) 。
1
2
3
4
5
6
7
|
$coll
=
$mo
->db->coll;
$c
=
array
(
'a'
=>1,
's'
=>
array
(
'$lt'
=>100));
$options
=
array
(
'safe'
=>true);
$rs
=
$coll
->remove(
$c
,
$options
);
|
更新数据库中的记录(MongoCollection对象) 。
1
2
3
4
5
6
7
8
9
|
$coll
=
$mo
->db->coll;
$c
=
array
(
'a'
=>1,
's'
=>
array
(
'$lt'
=>100));
$newobj
=
array
(
'e'
=>
'f'
,
'x'
=>
'y'
);
$options
=
array
(
'safe'
=>true,
'multiple'
=>true);
$rs
=
$coll
->remove(
$c
,
$newobj
,
$options
);
|
查询collection获得单条记录(MongoCollection类) 。
1
2
3
4
5
6
7
|
$coll
=
$mo
->db->coll;
$query
=
array
(
's'
=>
array
(
'$lt'
=>100));
$fields
=
array
(
'a'
=>true,
'b'
=>true);
$rs
=
$coll
->findOne(
$query
,
$fields
);
|
查询collection获得多条记录(MongoCollection类) 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
$coll
=
$mo
->db->coll;
$query
=
array
(
's'
=>
array
(
'$lt'
=>100));
$fields
=
array
(
'a'
=>true,
'b'
=>true);
$cursor
=
$coll
->find(
$query
,
$fields
);
//排序
$cursor
->sort(
array
(‘字段'=>-1));(-1倒序,1正序)
//跳过部分记录
$cursor
->skip(100);跳过100行
//只显示部分记录
$cursor
->limit(100);只显示100行
返回一个游标记录对象MongoCursor。
|
针对游标对象MongoCursor的操作(MongoCursor类) 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
$cursor
=
$coll
->find(
$query
,
$fields
);
while
(
$cursor
->hasNext()){
$r
=
$cursor
->getNext();
var_dump(
$r
);
}
//或者
$cursor
=
$coll
->find(
$query
,
$fields
);
foreache(
$cursor
as
$k
=>
$v
){
var_dump(
$v
);
}
//或者
$cursor
=
$coll
->find(
$query
,
$fields
);
$array
= iterator_to_array(
$cursor
);
|
。
最后此篇关于mongodb和php的用法详解的文章就讲到这里了,如果你想了解更多关于mongodb和php的用法详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我在 JavaScript 文件中运行 PHP,例如...... var = '';). 我需要使用 JavaScript 来扫描字符串中的 PHP 定界符(打开和关闭 PHP 的 )。 我已经知道使
我希望能够做这样的事情: php --determine-oldest-supported-php-version test.php 并得到这个输出: 7.2 也就是说,php 二进制检查 test.
我正在开发一个目前不使用任何框架的大型 php 站点。我的大问题是,随着时间的推移慢慢尝试将框架融入应用程序是否可取,例如在创建的新部件和更新的旧部件中? 比如所有的页面都是直接通过url服务的,有几
下面是我的源代码,我想在同一页面顶部的另一个 php 脚本中使用位于底部 php 脚本的变量 $r1。我需要一个简单的解决方案来解决这个问题。我想在代码中存在的更新查询中使用该变量。 $name)
我正在制作一个网站,根据不同的情况进行大量 PHP 重定向。就像这样...... header("Location: somesite.com/redirectedpage.php"); 为了安全起见
我有一个旧网站,我的 php 标签从 因为短标签已经显示出安全问题,并且在未来的版本中将不被支持。 关于php - 如何避免在 php 文件中写入
我有一个用 PHP 编写的配置文件,如下所示, 所以我想用PHP开发一个接口(interface),它可以编辑文件值,如$WEBPATH , $ACCOUNTPATH和 const值(value)观
我试图制作一个登录页面来学习基本的PHP,首先我希望我的独立PHP文件存储HTML文件的输入(带有表单),但是当我按下按钮时(触发POST到PHP脚本) )我一直收到令人不愉快的错误。 我已经搜索了S
我正在寻找一种让 PHP 以一种形式打印任意数组的方法,我可以将该数组作为赋值包含在我的(测试)代码中。 print_r 产生例如: Array ( [0] => qsr-part:1285 [1]
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: What is the max key size for an array in PHP? 正如标题所说,我想知道
我正在寻找一种让 PHP 以一种形式打印任意数组的方法,我可以将该数组作为赋值包含在我的(测试)代码中。 print_r 产生例如: Array ( [0] => qsr-part:1285 [1]
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我在 MySQL 数据库中有一个表,其中存储餐厅在每个工作日和时段提供的菜单。 表结构如下: i_type i_name i_cost i_day i_start i_
我有两页。 test1.php 和 test2.php。 我想做的就是在 test1.php 上点击提交,并将 test2.php 显示在 div 中。这实际上工作正常,但我需要向 test2.php
我得到了这个代码。我想通过textarea更新mysql。我在textarea中回显我的MySQL,但我不知道如何更新它,我应该把所有东西都放进去吗,因为_GET模式没有给我任何东西,我也尝试_GET
首先,我是 php 的新手,所以我仍在努力学习。我在 Wordpress 上创建了一个表单,我想将值插入一个表(data_test 表,我已经管理了),然后从 data_test 表中获取所有列(id
我有以下函数可以清理用户或网址的输入: function SanitizeString($var) { $var=stripslashes($var); $va
我有一个 html 页面,它使用 php 文件查询数据库,然后让用户登录,否则拒绝访问。我遇到的问题是它只是重定向到 php 文件的 url,并且从不对发生的事情提供反馈。这是我第一次使用 html、
我有一个页面充满了指向 pdf 的链接,我想跟踪哪些链接被单击。我以为我可以做如下的事情,但遇到了问题: query($sql); if($result){
我正在使用 从外部文本文件加载 HTML/PHP 代码 $f = fopen($filename, "r"); while ($line = fgets($f, 4096)) { print $l
我是一名优秀的程序员,十分优秀!