YII2操作mongodb笔记(转)

返回博客列表

原 YII2操作mongodb笔记

风清扬-深圳

  • 发布时间: 2015/12/17 15:20
  • 阅读: 895
  • 收藏: 2
  • 点赞: 0
  • 评论: 0

操作之前得保证已经安装了mongodb,windows下安装可参考另一篇博文:

http://my.oschina.net/chinahub/blog/479268

componets配置:

‘mongodb‘ => [
    ‘class‘ => ‘\yii\mongodb\Connection‘,
    ‘dsn‘ => ‘mongodb://test:[email protected]:27017/yiimongodb‘,
],

控制器:

<?php
namespace frontend\controllers;
use Yii;
use yii\helpers\Url;
use yii\mongodb\Query;
use yii\web\Controller;
use yii\data\ActiveDataProvider;
use frontend\models\Customer;
class MonController extends Controller
{
    public function actionIndex()
    {
        $collection = Yii::$app->mongodb->getCollection ( ‘customer‘ );
        $res = $collection->insert ( [ 
        ‘name‘ => ‘John Smith22‘,
        ‘status‘ => 2 
        ] );
        var_dump($res);
    }
    public function actionList()
    {
        $query = new Query ();
        $query->select ( [ 
        ‘name‘,
        ‘status‘ 
        ] )->from ( ‘customer‘ )->offset ( 10 )->limit ( 10 );
        $rows = $query->all ();
        var_dump ( $rows );
    }
    public function actionView()
    {
        $query = new Query ();
        $row = $query->from ( ‘customer‘ )->one ();
        echo Url::toRoute ( [ 
        ‘item/update‘,
        ‘id‘ => ( string ) $row [‘_id‘] 
        ] );
        var_dump ( $row [‘_id‘] );
        var_dump ( ( string ) $row [‘_id‘] );
    }
    public function actionFind()
    {
        $provider = new ActiveDataProvider ( [ 
        ‘query‘ => Customer::find (),
        ‘pagination‘ => [ 
        ‘pageSize‘ => 10 
        ] 
        ] );
        $models = $provider->getModels ();
        var_dump ( $models );
    }
    public function actionQuery()
    {
        $query = new Query ();
        $query->from ( ‘customer‘ )->where ( [ 
        ‘status‘ => 2 
        ] );
        $provider = new ActiveDataProvider ( [ 
        ‘query‘ => $query,
        ‘pagination‘ => [ 
        ‘pageSize‘ => 10 
        ] 
        ] );
        $models = $provider->getModels ();
        var_dump ( $models );
    }
    public function actionSave()
    {
        $res = Customer::saveInfo ();
        var_dump ( $res );
    }
}

模型:

<?php
namespace frontend\models;
use yii\mongodb\ActiveRecord;
class Customer extends ActiveRecord
{
    public static function collectionName()
    {
        return ‘customer‘;
    }
    public function saveInfo()
    {
        $customer = new Customer ();
        $customer->name = ‘111‘;
        $customer->email = ‘222‘;
        $customer->insert ();
        return $customer;
    }
    public function attributes()
    {
        return [ 
        ‘_id‘,
        ‘name‘,
        ‘email‘,
        ‘address‘,
        ‘status‘ 
        ];
    }
}

YII2的mongodb拓展下载:

https://github.com/yiisoft/yii2-mongodb

中文网址:

http://www.runoob.com/

http://www.mongoing.com/

http://www.cnblogs.com/libingql/archive/2011/06/09/2076440.html

常用命令 ,同mysql,eg:

db.createUser({"user":"test","pwd":"123456","roles":["readWrite","dbAdmin"]})

show users;

show dbs;

db.version();

db.stats();

use yiimongodb;

show collections;

时间: 2024-12-04 12:43:15

YII2操作mongodb笔记(转)的相关文章

mongoose 操作 mongodb 笔记 (自己的笔记,自己看的)

mongodb下载/安装 mongoose   npm install --save mongoose mongoose 数据库连接 const mongoose = require('mongoose') const DB_RUL = 'mongodb://localhost:27017/koa2' mongoose.connect(DB_RUL, function(err){ if(err){ console.warn('数据库连接失败:'+err) }else{ console.log('

Nodejs学习笔记(二)--- 操作MongoDB数据库

最近看了一些关于mongodb的文章,然后就想知道nodeJS是怎么连接的所以我就尝试去了解了一波(这个菜鸟驿站这个网站还不错,虽然知识文档不是最新的,但是还是蛮好的: 顺便官网地址是这个哦:http://mongoosejs.com/docs/guide.html 好了,让我们来进入今天的主题: 首先来进入你项目的根目录下安装: npm install  mongoose 一直想用下这个数据的,最近终于得偿所愿.数据库的使用,我觉得首先是从增删改查开始,然后才去像更加复杂的地步去卖家首先如何去

Fedora上使用Python操作MongoDB学习笔记

1. 创建Python虚拟环境 Fedora中已经安装有Python2和Python3,可执行文件的目录在/usr/bin/目录下,其中软连接为 python->python2 python2->python2.x python3->python3.x 接下来采用Python3来操作MongoDB,因此为不污染原有的系统环境,以及隔离此特定应用,采用Python虚拟环境的方式. 创建虚拟环境 语法 $ python3 -m venv /path/to/new/virtual/enviro

PHP操作MongoDB技术总结

<?php /** * PHP操作MongoDB学习笔记 */ //************************* //** 连接MongoDB数据库 **// //************************* //格式=>("mongodb://用户名:密码 @地址:端口/默认指定数据库",参数) $conn = new Mongo(); //可以简写为 //$conn=new Mongo(); #连接本地主机,默认端口. //$conn=new Mongo(&

PHP操作MongoDB技術總結

PHP操作MongoDB技術總結 <?php /** * PHP操作MongoDB学习笔记 */ //************************* //**   连接MongoDB数据库  **// //************************* //格式=>(“mongodb://用户名:密码 @地址:端口/默认指定数据库”,参数) $conn = new Mongo(); //可以简写为 //$conn=new Mongo(); #连接本地主机,默认端口. //$conn=n

Ruby操作MongoDB(进阶)-CRUD操作

MongDB数据库的使用离不开CRUD操作.什么是CRUD,就是创建文档,读取文档信息,更新文档和删除文档. key-value键值对标记 在MongoDB的Ruby驱动中,Key_value键值多次出现.而且有时会出现语法上的巧合,这取决于在使用的Ruby版本中如何申明. 在文档创建步骤中,1.9及之后版本支持以下语法: document={name:"Tom",age:20}. 但是如果你使用的是2.2或者更高的版本,你可以用双引号将你的key包起来.如: document={&q

node操作MongoDB数据库之插入

在上一篇中我们介绍了MongoDB的安装与配置,接下来的我们来看看在node中怎样操作MongoDB数据库. 在操作数据库之前,首先应该像关系型数据库一样建个数据库把... 启动数据库 利用命令提示符: 1.在创建数据库之前,我们应该启动数据库服务器 mongod --dbpath d:\MongoDB\data 注意:不要关闭这个数据库服务器...不然数据库就被关闭了 2.使用如下语句创建一个数据库 use mydb 这样mongodb会帮助我们自动创建他们,当然这个时候数据库还是空的. 3.

学习MongoDB--(11):应用举例(利用java操作MongoDB)

原文地址:http://blog.csdn.net/drifterj/article/details/7948090 目录地址:http://blog.csdn.net/DrifterJ/article/category/1191327/2 前面我们都是通过shell来操作存取MongoDB的数据,shell中使用的语言就是javascript.我们这次说一下如何通过Java来访问操作MongoDB数据库的. Java驱动程序是MongoDB最早的驱动,已用于生产环境很长时间,十分稳定.可以到M

【转】PHP操作MongoDB GridFS 存储文件

PHP操作MongoDB GridFS 存储文件,如图片文件 GridFS是MongoDB的一个内置功能,它提供一组文件操作的API以利用MongoDB存储文件,GridFS的基本原理是将文件保存在两个Collection中,一个保存文件索引,一个保存文件内容,文件内容按一定大小分成若干块,每一块存在一个Document中,这种方法不仅提供了文件存储,还提供了对文件相关的一些附加属性(比如MD5值,文件名等等)的存储.