Tutorial MongoD...login
Tutorial MongoDB
pengarang:php.cn  masa kemas kini:2022-04-21 17:49:03

MongDB PHP7


Pemasangan dan Penggunaan PHP7 MongDB

Tutorial ini hanya sesuai untuk persekitaran PHP7 Jika anda berada dalam persekitaran PHP5, anda boleh merujuk kepada Pemasangan dan Penggunaan PHP MongDB<🎜. >.

Pemasangan sambungan PHP7 Mongdb

Kami menggunakan arahan pecl untuk memasang:

$ /usr/local/php7/bin/pecl install mongodb

Selepas pelaksanaan berjaya, keputusan berikut akan dikeluarkan:

……
Build process completed successfully
Installing '/usr/local/php7/lib/php/extensions/no-debug-non-zts-20151012/mongodb.so'
install ok: channel://pecl.php.net/mongodb-1.1.7
configuration option "php_ini" is not set to php.ini location
You should add "extension=mongodb.so" to php.ini

Seterusnya kami membuka fail php.ini, tambah konfigurasi

extension=mongodb.so.

Anda boleh terus melaksanakan arahan berikut untuk menambah.

$ echo "extension=mongodb.so" >> `/usr/local/php7/bin/php --ini | grep "Loaded Configuration" | sed -e "s|.*:\s*||"`

Nota: Dalam arahan yang dilaksanakan di atas, direktori pemasangan php7 ialah /usr/local/php7/ Jika anda memasangnya dalam direktori lain, anda perlu mengubah suai arahan pecl dan php dengan sewajarnya.


Mongodb Gunakan

PHP7 untuk menyambung ke MongoDB Sintaks adalah seperti berikut:

$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");

Sisipkan data

Tetapkan nama. kepada "php中文网" Data dimasukkan ke dalam koleksi php pangkalan data ujian.

<?php
$bulk = new MongoDB\Driver\BulkWrite;
$document = ['_id' => new MongoDB\BSON\ObjectID, 'name' => 'php中文网'];

$_id= $bulk->insert($document);

var_dump($_id);

$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");  
$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);
$result = $manager->executeBulkWrite('test.php', $bulk, $writeConcern);
?>

Baca data

Di sini kami memasukkan tiga data URL ke dalam koleksi tapak pangkalan data ujian, dan membaca serta mengulanginya:

<?php
$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");  

// 插入数据
$bulk = new MongoDB\Driver\BulkWrite;
$bulk->insert(['x' => 1, 'name'=>'php中文网', 'url' => 'http://www.php.cn']);
$bulk->insert(['x' => 2, 'name'=>'Google', 'url' => 'http://www.google.com']);
$bulk->insert(['x' => 3, 'name'=>'taobao', 'url' => 'http://www.taobao.com']);
$manager->executeBulkWrite('test.sites', $bulk);

$filter = ['x' => ['$gt' => 1]];
$options = [
    'projection' => ['_id' => 0],
    'sort' => ['x' => -1],
];

// 查询数据
$query = new MongoDB\Driver\Query($filter, $options);
$cursor = $manager->executeQuery('test.sites', $query);

foreach ($cursor as $document) {
    print_r($document);
}
?>

Hasil output ialah:

stdClass Object
(
    [x] => 3
    [name] => taobao
    [url] => http://www.taobao.com
)
stdClass Object
(
    [x] => 2
    [name] => Google
    [url] => http://www.google.com
)

Kemas kini data

Seterusnya kami akan mengemas kini data di mana x ialah 2 dalam koleksi tapak pangkalan data ujian:

<?php
$bulk = new MongoDB\Driver\BulkWrite;
$bulk->update(
    ['x' => 2],
    ['$set' => ['name' => 'php工具', 'url' => 'tool.php.cn']],
    ['multi' => false, 'upsert' => false]
);

$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");  
$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);
$result = $manager->executeBulkWrite('test.sites', $bulk, $writeConcern);
?>

Seterusnya kami menggunakan "db.sites.find( )" arahan Semak perubahan dalam data. Data dengan x sebagai 2 telah ditukar menjadi alat php:

Padam data

Contoh berikut memadam x sebagai 1 dan x sebagai 2 data, perhatikan perbezaan dalam parameter had:

<?php
$bulk = new MongoDB\Driver\BulkWrite;
$bulk->delete(['x' => 1], ['limit' => 1]);   // limit 为 1 时,删除第一条匹配数据
$bulk->delete(['x' => 2], ['limit' => 0]);   // limit 为 0 时,删除所有匹配数据

$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");  
$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);
$result = $manager->executeBulkWrite('test.sites', $bulk, $writeConcern);
?>

Untuk kaedah penggunaan lanjut, sila rujuk:

http://php.net/manual/en/ book.mongodb.php.