sql >> Databasteknik >  >> NoSQL >> MongoDB

MongoDB och CodeIgniter

Jag är inte säker på om det är "CodeIgniter-sättet", men jag skapade ett CodeIgniter-bibliotek som utökar Mongo-klassen med en extra egenskap för att lagra den aktuella databasanslutningen.

Här är de relevanta kodfilerna från mitt projekt.

config/mongo.php

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

bibliotek/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;
    }
}

Och en provkontroll

controllers/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);
    }
}


  1. Guide till hur du använder Apache HBase-portar

  2. Mongoose med mongodb hur returnerar man just sparat objekt?

  3. Hur får man flera dokument med en array av MongoDb-id?

  4. Matcha ett arrayfält som innehåller valfri kombination av den tillhandahållna arrayen i MongoDB