国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 數據庫 > MongoDB > 正文

PHP中MongoDB數據庫的連接、添加、修改、查詢、刪除等操作實例

2020-10-29 18:54:07
字體:
來源:轉載
供稿:網友

PHP 擴展mongon.mod.dll下載http://cn.php.net/manual/en/mongo.installation.php#mongo.installation.windows
然后php.ini添加 extension=php_mongo.dll
最后phpinfo() 查找到


表標PHP已經自帶了mongo功能,你就可以操作下面的代碼(但是你必須有安裝mongodb服務器)

一、連接數據庫

使用下面的代碼創建一個數據庫鏈接

復制代碼 代碼如下:
<?php
$connection = new Mongo(mongodb://192.168.1.5:27017); //鏈接到 192.168.1.5:27017//27017端口是默認的。
$connection = new Mongo( "example.com" ); //鏈接到遠程主機(默認端口)
$connection = new Mongo( "example.com:65432" ); //鏈接到遠程主機的自定義的端口
print_r($connection->listDBs());//能打印出數據庫數組,看看有幾個數據庫。

?>

如圖:


上圖說有一個數據庫名字叫local,總大小1個字節,他是空的。看見ok表示運行成功。

現在你可以使用$connection鏈接來操作數據庫了

選擇數據庫

使用下面的代碼來選擇一個數據庫

復制代碼 代碼如下:
<?php
$db = $connection->dbname;
?>

這里的數據庫并不一定是一個已經存在的數據庫,如果所選擇的數據庫不存在,則會新建一個數據庫,所以在選擇數據庫的時候,注意一定要填上正確的數據庫名
如果拼寫錯誤的話,很有可能會新建一個數據庫

復制代碼 代碼如下:
<?php
$db = $connection->mybiglongdbname;
//做一些事情
$db = $connection->mybiglongdbnme;
//現在會連上一個新的數據庫
?>

獲取一個集合

獲取一個集合跟選擇數據庫擁有相同的語法格式

復制代碼 代碼如下:
<?php
$db = $connection->baz;//選擇數據庫
$collection = $db->foobar;//選擇foobar集合
//或者使用更簡潔的方式
$collection = $connection->baz->foobar;
?>

插入一個文檔

多維數組是可以被儲存到數據庫中的基本單元
一個隨機的文檔可能是這樣

復制代碼 代碼如下:
<?php
$doc = array(
 ”name” => “MongoDB”,
    “type” => “database”,
    “count” => 1,
    “info” => (object)array( “x” => 203,
    “y” => 102),
    “versions” => array(“0.9.7″, “0.9.8″, “0.9.9″)
);
?>

注意:你可以嵌套數組與對象,對象與文檔在mongodb中幾乎是一樣的,你可以使用$doc調用一個文檔或對象,但是info字段總是一個對象而不是一個文檔,
本約束適用于所有文檔
使用MongoCollection::insert()插入一個文檔

復制代碼 代碼如下:
<?php
$m = new Mongo();
$collection = $m->foo->bar;
$collection->insert($doc);
?>

mongodb 的 insert()、save()  ,區別主要是:若存在主鍵,insert()  不做操作,而save() 則更改原來的內容為新內容。
存在數據:  { _id : 1, " name " : " n1 " }
insert({ _id : 1, " name " : " n2 " })    會提示錯誤
save({ _id : 1, " name " : " n2 " })     會把 n1 改為  n2  。

使用MongoCollection::findOne()查詢文檔

為了證明上面那段代碼的數據已經插入到數據庫里了,我們進行簡單的 findOne()操作以得到集合中的第一個文檔數據,這種方法只返回一個文檔數據,
這種方法適用于在你的查詢語句的時候只匹配一個文檔或者你只關心第一條數據

復制代碼 代碼如下:
<?php
$obj = $collection->findOne();
var_dump( $obj );
?>

你會看到下列結果

復制代碼 代碼如下:
array(5) {
  ["_id"]=>
  object(MongoId)#6 (0) {
  }
  ["name"]
  string(7) “MongoDB”
  ["type"]=>
  string(8) “database”
  ["count"]=>
  int(1)
  ["info"]=>
  array (2) {
    ["x"]=>
    int(203)
    ["y"]=>
    int(102)
  }
  ["versions"]
  array(3) {
    [0]=>
    string(5) “0.9.7″
    [1]=>
    string(5) “0.9.8″
    [2]=>
    string(5) “0.9.9″
  }
}

注意_id字段自動加載了文檔上,MongoDB儲存元素中以_以及$開頭的都是供內部使用的

添加更多文檔

為了做一些更有趣的事情,我們添加更多簡單的文檔到集合中,這些文檔如下

復制代碼 代碼如下:
<?php
array( “i” => value );
?>

我們可以使用循環相當有效的插入數據
復制代碼 代碼如下:
<?php
for($i=0; $i<100; $i++) {
    $collection->insert( array( “i” => $i ) );
}
?>

注意:我們可以插入不同的字段在同一字符集中,在這方面意味著MongoDB擁有非常自由的儲存模式

在一個集合中計算文檔的數量

現在我們插入了101個文檔(我們用循環插入了100個,之前還插入了一個),我們可以使用count()來看看我們的數據是不是都被插入進去了

復制代碼 代碼如下:

<?php
echo $collection->count();
?>

這段代碼將打印出101

MongoCollection::count() 也可以查詢字段數據

使用游標得到集合中的所有文檔

為了得到集合中的所有文檔,我們可以使用 MongoCollection::find()方法,find()方法返回一個 MongoCursor對象,可以讓我們重復得到查詢所匹配的的文檔

復制代碼 代碼如下:
<?php
$cursor = $collection->find();
foreach ($cursor as $id => $value) {
    echo “$id: “;
    var_dump( $value );
}
?>

這樣我們會打印出集合中的這101個文檔,$id就是文檔中的_id字段,$value 就是文檔本身

為查詢規定一個標準
我們可以通過find()方法得到集合中的文檔子集,例如,我們要查詢出集合中i字段為71的文檔,我們可以使用下列方法

復制代碼 代碼如下:
<?php
$query = array( “i” => 71 );
$cursor = $collection->find( $query );
while( $cursor->hasNext() ) {
    var_dump( $cursor->getNext() );
}
?>

我們將打印如下數據
復制代碼 代碼如下:
array(2) {
  ["_id"]=>
  object(MongoId)#6 (0) {
  }
  ["i"]=>
  int(71)
  ["_ns"]=>
  “testCollection”
}

為查詢設定一個范圍

我們可以通過find()創建一個查詢語句以得集合中的一個子集,例如如果我們得到所有”i”>50的文檔,我們可以使用如下代碼

復制代碼 代碼如下:
<?php
$query = array( “i” => array(‘$gt' =>50)); //注意'$gt'兩邊的單引號
$cursor = $coll->find( $query );
while( $cursor->hasNext() ) {
    var_dump( $cursor->getNext() );
}
?>

我們同樣可以得到20 < i <= 30之間的數據

復制代碼 代碼如下:
<?php
$query = array( “i” => array( “/$gt” => 20, “/$lte” => 30 ) );
$cursor = $coll->find( $query );
while( $cursor->hasNext() ) {
    var_dump( $cursor->getNext() );
}
?>

我們非常容易漏掉$美元符號,你也可以選擇你自定義的符號來代替美元符號,選擇一個不會在你的建里面出現的符號例如”:”,在php.ini中加上這么一句話

復制代碼 代碼如下:
mongo.cmd = “:”

那么上面的代碼就可以替換成
復制代碼 代碼如下:
<?php
$query = array( “i” => array( “:gt” => 20, “:lte” => 30 ) );
?>

當然你也可以使用ini_set(“mongo.cmd”, “:”)的方法來改變

創建一個索引

MongoDB支持索引,并且可以很容易的加到一個集合中,你只要指定某個字段為索引就行了,并且還可以指定 正序索引(1)與 倒序索引(-1)
下面的代碼為I創建了索引

復制代碼 代碼如下:
<?php
$coll->ensureIndex( array( “i” => 1 ) );  //在”i”上創建了一個索引
$coll->ensureIndex( array( “i” => -1, “j” => 1 ) );//在”i”上創建了倒序索引 在”j”上創建了正序索引
?>

一個完整的簡單例子

這個例子展示了如何鏈接mongodb數據庫,如何選擇數據庫,如何插入數據,如何查詢數據,以及關閉數據庫鏈接

復制代碼 代碼如下:
<?php
//鏈接
$m = new Mongo();

// 選擇一個數據庫
$db = $m->comedy;
$collection = $db->cartoons;

//添加一個元素
$obj = array( "title" => "Calvin and Hobbes", "author" => "Bill Watterson" );
$collection->insert($obj);

//修改
$newdata = array('$set' => array("title" => "Calvin and Hobbes"));
$collection->update(array("author" => "caleng"), $newdata);
//刪除
$collection->remove(array('author'=>'caleng'), array("justOne" => true));

//添加另一個元素,使用不同的格式
$obj = array( "title" => "XKCD", "online" => true );
$collection->insert($obj);

//查詢所有的集合
$cursor = $collection->find();

//重復顯示結果
foreach ($cursor as $obj) {
    echo $obj["title"] . "/n";
}

// 關閉鏈接
$m->close();
?>


輸出結果為
復制代碼 代碼如下:
Calvin and Hobbes
XKCD

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
亚洲伊人网在线观看| 欧美日韩视频精品一区二区| 国内外激情在线| www.国产精品.com| 在线观看中文| 国产成人亚洲欧美电影| 开心激情五月婷婷| 久草一本av| 中文字幕亚洲免费| 一级二级在线观看| 高清av在线| 国产精品视频一区麻豆| 中文日本在线观看| 九九99九九精彩| 国产成人精品久久一区二区小说 | 一区二区免费播放| 免费电影网站在线视频观看福利| 免费av不卡在线观看| 丁香花在线电影小说观看| 天天av天天爽| heisi视频网在线观看| 丁香花在线电影小说观看| 国产aa视频| 国产理论在线观看| 亚洲欧美国产另类首页| 国产三级视频在线播放线观看| 午夜亚洲成人| 国产精品久久一区二区三区不卡| 欧美色第一页| 夜夜操天天干| 国产精品久久久久一区二区国产| 免费三级毛片| 在线激情小视频| 国产午夜在线观看| 久热中文字幕精品视频在线| av高清在线| 伊人中文在线| √天堂资源中文www| 国产精品186在线观看在线播放| 开心激情五月婷婷| 热99在线观看| 超碰免费在线| 国产69精品久久久久孕妇国产69久久 | 成人欧美日韩| 国产精品理人伦一区二区三区| 色中文字幕在线| 在线久久视频| www.夜夜操.com| 精品资源在线看| 国产老肥熟xxxx在线观看| www.99色.com| 久久99精品久久久久久野外| 高潮白浆视频| 国产调教视频在线观看| 国产鲁鲁视频在线观看免费| 中文字幕免费中文| 91精品专区| 欧美日韩在线视频免费观看 | 在线视频观看亚洲| 思思99精品视频在线观看| 日本福利在线| 国产毛片视频| 国产青青草在线| 99re在线视频播放| 免费看黄视频网站| 国产九九九九| 18成年在线观看| 免费高清av| 1区2区3区在线| av二区三区| 国产免费人人看| 精品全国在线一区二区| 久久精品国产麻豆| 国产盗摄精品一区二区酒店| eeuss在线观看| 国产视频资源| 欧美午夜电影一区二区三区| 中文字幕第一页av| 日本在线视频www鲁啊鲁| 国产美女在线免费观看| 亚洲最新永久观看在线| 国产剧情在线一区| av在线资源网| 国产在线免费观看| 国产高清一级片| 九九热视频在线观看| 在线观看av中文| 国产叼嘿网站免费观看不用充会员| 免费看黄视频网站| 日本亚洲欧美| 亚洲91av| www.91在线播放| 18av在线视频| 国产91在线视频蝌蚪| 国产亚洲精品拍拍拍拍拍| 浪潮av一区| www在线视频| 欧美日韩在线中文字幕| 精品久久亚洲一级α| 国产三级视频在线| 国产污污在线观看| 中文字幕亚洲精品视频| 99热在线免费播放| 最近免费中文字幕在线第一页 | 国产美女在线一区二区三区| 欧美日韩在线精品成人综合网| 伊人av免费在线观看| 国产国语**毛片高清视频 | 成在线人视频免费视频| 天天操中文字幕视频| 亚洲第一成年免费网站| 日韩亚洲一区中文字幕| 日本福利午夜视频在线| 日本电影全部在线观看网站视频| 亚洲视频在线观看不卡| 人人在线视频| 国产免费电影网站入口| 国产一级黄色电影| 18av在线视频| 人人干人人插| 国产一级电影网| 中文天堂av| 超碰在线网站| 国产福利av网站| www在线视频| 国产小视频免费在线观看| 91这里只有精品| 欧洲有码在线视频| 国产天堂在线| 色综合久久五月天| 99热在线免费播放| 精品国内一区二区三区免费视频 | 精品999视频| 麻豆电影传媒二区| 国产人成精品| 日本一本久久| 国产高清一级片| 国产在线www| www.亚洲视频| 尤物在线精品视频| 国产免费人人看| 亚洲第一区视频| 精品网站www| 国产午夜在线视频| 超碰免费在线观看| 99热国产在线| 国产激情视频在线| 免费精品国产自产拍观看| 在线观看免费黄色| 国产成人夜间影院在线观看| 国产美女性感在线观看懂色av| 精品一区二区三区高清免费不卡| 狠狠狠狠狠狠操| 免费在线黄色网址| av中文资源在线| 中文字幕2019第三页| 国产激情视频一区二区| 国产午夜三区视频在线| 五月综合网站| 国产裸舞福利在线视频合集 | av免费在线观看网站| 国产精品视频二区三区| 激情丁香久久| 日本成人免费网站| 欧美性猛交xxxx免费看蜜桃| 午夜影院免费| 超碰免费在线播放| 福利在线视频导航| 好男人社区在线视频| 黄色av免费看| 国产九九九九| 国产偷窥洗澡视频| 国产高清视频在线观看| 中文在线视频观看| 四虎中文字幕| 国产在线观看18| 国产馆av播放| 日韩不卡高清| 九七电影韩国女主播在线观看| 九九视频精品在线| 国产一卡2卡3卡四卡网站| 国产图片综合| 在线亚洲电影| 人成在线免费视频| 中文字幕网在线| 伊人影院蕉久影院在线播放| 久草国产视频| 中文国产字幕在线观看| gogo高清在线播放免费| 丁香综合五月| 亚洲人av在线| 国产一二三区在线视频| 在线国产网址| 好男人免费精品视频| 国产精品久久精品牛牛影视| 亚洲精品在线视频免费| 日本中文字幕在线播放| h视频在线网站| 国产对白在线| 国产麻豆高清视频在线第一页 |