soupmix/mongodb

此包已被 废弃 并不再维护。没有建议的替代包。

简单的 MongoDB 抽象层适配器,用于处理 CRUD 操作。

0.8.1 2017-08-02 14:20 UTC

This package is auto-updated.

Last update: 2021-06-26 15:24:47 UTC


README

Build Status Latest Stable Version Total Downloads Latest Unstable Version License Scrutinizer Code Quality Code Coverage

使用 PHP 编写的简单 MongoDB 抽象层适配器,用于处理 CRUD 操作。此库不提供任何 ORM 或 ODM。

安装

建议您使用 Composer 安装 Soupmix。

$ composer require soupmix/mongodb "~0.7"

这将安装 Soupmix 和所有必需的依赖项。Soupmix 需要 PHP 5.6.0 或更高版本,mongodb 扩展:1.1.0 或更高版本,MongoDB 的 mongo-php-library 1.0.2 库或更高版本。

文档

API 文档:查看数据库适配器函数的详细信息

用法

// Connect to MongoDB Service
$adapter_config = [];
$adapter_config['db_name'] ='db_name';
$adapter_config['connection_string']="mongodb://127.0.0.1";
$adapter_config['options'] =[];
$config['db_name'] = $adapter_config;
$client = new \MongoDB\Client($adapter_config['connection_string'], $adapter_config['options']);
$m=new Soupmix\MongoDB($config, $client);


$docs = [];
$docs[] = [
    "full_name" => "John Doe",
      "age" => 33,
      "email"    => "johndoe@domain.com",
      "siblings"=> [
        "male"=> [
          "count"=> 1,
          "names"=> ["Jack"]
        ],
        "female"=> [
          "count" => 1,
          "names" =>["Jane"]
        ]      
      ]
];
$docs[] = [
    "full_name" => "Jack Doe",
      "age" => 38,
      "email"    => "jackdoe@domain.com",
      "siblings"=> [
        "male"=> [
          "count"=> 1,
          "names"=> ["John"]
        ],
        "female"=> [
          "count" => 1,
          "names" =>["Jane"]
        ]      
      ]
];

$docs[] = [
    "full_name" => "Jane Doe",
      "age" => 29,
      "email"    => "janedoe@domain.com",
      "siblings"=> [
        "male"=> [
          "count"=> 2,
          "names"=> ["Jack","John"]
        ],
        "female"=> [
          "count" => 0,
          "names" =>[]
        ]      
      ]
];

foreach($docs as $doc){
    // insert user into database
    $mongo_user_id = $m->insert("users",$doc);
}
// get user data using id
$user_data = $m->get('users', $mongo_user_id);


$filter = ['age_gte'=>0];
// update users' data that has criteria encoded in $filter
$set = ['is_active'=>1,'is_deleted'=>0];

$i = $m->update("users", $filter, $set);

$filter = ["siblings.male.count__gte"=>2];

//delete users that has criteria encoded in $filter
$m->delete('users', $filter);



// user's age lower_than_and_equal to 34 or greater_than_and_equal 36 but not 38
$filter = [[['age__lte'=>34],['age__gte'=>36]],"age__not"=>38];

//find users that has criteria encoded in $filter
$docs = $m->find("users", $filter);


贡献

  • 如果发现错误,请提交问题或发送 pull request。
  • 如果您有任何问题,请随时提出。