MongoCollection::insert ( array $a [, array $options = array() ] )
该方法的第二个参数的使用
'safe':传入一个布尔值或者整数,默认为false。如果为false,该语句后的程序会继续执行,而无需等待数据库的响应。也就是不论插入数据成功与否都不会中断程序。
'fsync':默认为false,如果为true表示强制将数据同步到磁盘,前一个'safe'设置将会已false覆盖。
ps:使用mongodb时,曾遇到过一个进程插入数据库,另一个进程不能立刻读到数据 ,原来是mongodb插入数据不一定会立刻写入磁盘。
'timeout':设置超时时间
如果该方法的第二个参数只传入true,如下这样:
$mongo = new Mongo("192.168.8.249:27017");
$conn = $mongo->test->table1;
$data = array(....);
$conn->insert($data, true);
我们默认为safe参数设置为true
=========================================================
关于索引
<?php
$mongo = new Mongo("192.168.8.249:27017");
$conn = $mongo->test->table;
$conn->ensureIndex(array("a" => 1,"b" => 1));$award = array(
'a' => array(1),
'b' => array(2),
);$conn->insert($award, true);
如果我们建立了联合索引,在插入数据的时候,建立索引的这两个字段均为数组,会得到以下报错
“cannot index parallel arrays”
所以我们建立联合索引的字段不能均为数组