57

任何人都可以帮助我指向一个教程、库等,让我可以从 CodeIgniter 使用 MongoDB 吗?

4

5 回答 5

54

我不确定它是否是“CodeIgniter 方式”,但我创建了一个 CodeIgniter 库,它使用额外的属性扩展了 Mongo 类来存储当前的数据库连接。

这是我项目中的相关代码文件。

配置/mongo.php

$config['mongo_server'] = null;
$config['mongo_dbname'] = 'mydb';

库/Mongo.php

class CI_Mongo extends Mongo
{
    var $db;

    function CI_Mongo()
    {   
        // Fetch CodeIgniter instance
        $ci = get_instance();
        // Load Mongo configuration file
        $ci->load->config('mongo');

        // Fetch Mongo server and database configuration
        $server = $ci->config->item('mongo_server');
        $dbname = $ci->config->item('mongo_dbname');

        // Initialise Mongo
        if ($server)
        {
            parent::__construct($server);
        }
        else
        {
            parent::__construct();
        }
        $this->db = $this->$dbname;
    }
}

和一个示例控制器

控制器/posts.php

class Posts extends Controller
{
    function Posts()
    {
        parent::Controller();
    }

    function index()
    {
        $posts = $this->mongo->db->posts->find();

        foreach ($posts as $id => $post)
        {
            var_dump($id);
            var_dump($post);
        }
    }

    function create()
    {
        $post = array('title' => 'Test post');
        $this->mongo->db->posts->insert($post);
        var_dump($post);
    }
}
于 2010-02-15T18:32:17.377 回答
15

MongoDB 在 CodeIgniter 社区中得到了很好的支持,请花时间潜入:p

于 2012-08-13T16:56:14.600 回答
11

我喜欢 Stephen Curran 的示例,因为它很简单,并且允许在没有在 Php 中编写太多功能的情况下提供与 Mongo 的接口,我往往会发现大量的抽象类有时对于我所追求的东西有点多。

我已经扩展了他的示例以包括数据库身份验证。去这里:http ://www.mongodb.org/display/DOCS/Security+and+Authentication了解 mongo 身份验证,不要忘记为您连接的 Mongo 服务器启用身份验证。

我还将旧式构造函数更改为 __construct 并且正在处理 Mongo 连接异常,因为它们会泄露您的用户名和密码。

配置/mongo.php

<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

$config['mongo_server'] = 'localhost';
$config['mongo_dbname'] = 'my_mongo_db';
$config['mongo_username'] = 'mongo_user';
$config['mongo_password'] = 'password1234';

/* End of file mongo.php */

库/Mongo.php

<?php

class CI_Mongo extends Mongo{

    protected $db;

    function __construct()
    {   
        // Fetch CodeIgniter instance
        $ci = get_instance();
        // Load Mongo configuration file
        $ci->load->config('mongo');

        // Fetch Mongo server and database configuration
        $server = $ci->config->item('mongo_server');
        $username = $ci->config->item('mongo_username');
        $password = $ci->config->item('mongo_password');
        $dbname = $ci->config->item('mongo_dbname');

        // Initialise Mongo - Authentication required
        try{
            parent::__construct("mongodb://$username:$password@$server/$dbname");
            $this->db = $this->$dbname;
        }catch(MongoConnectionException $e){
            //Don't show Mongo Exceptions as they can contain authentication info
            $_error =& load_class('Exceptions', 'core');
            exit($_error->show_error('MongoDB Connection Error', 'A MongoDB error occured while trying to connect to the database!', 'error_db'));           
        }catch(Exception $e){
            $_error =& load_class('Exceptions', 'core');
            exit($_error->show_error('MongoDB Error',$e->getMessage(), 'error_db'));           
        }
    }
}
于 2011-11-18T17:33:51.440 回答
6

在 CodeIgniter 中使用 MongoDB 与在其他任何地方使用它并没有太大区别。

您可以将一个 MongoDB 库组合在一起,该库将在构造函数中连接并存储 $this->conn 以供稍后在方法中使用。

然后要么直接使用控制器中的 conn 属性,要么在 MongoDB 库中创建一些方法来为您执行此操作。

看看这里查看使用 MongoDB 的普通 PHP 教程。

我很乐意为此为您创建一个库,但它需要付出代价。:-p

于 2010-02-12T11:55:33.970 回答
2

我正在使用带有 CI 的 MongoDB,并提出了以下建议。它对我有用,但我确信它可以进行一些调整。我会担心稍后对其进行调整,但现在它可以满足我的要求。

我创建了一个名为“database_conn.php”的模型

class Database_Conn extends Model {

    function _connect() {
        $m = new Mongo();

        $db = $m->selectDB( "YOUR DATABASE NAME" );
        return $db;
    }
}

然后,如果我需要从我的模型连接到一个集合。

$collection = Database_Conn::_connect()->selectCollection( "COLLECTION NAME" );
于 2010-03-04T18:54:18.653 回答