美文网首页数据库
在laravel中使用mongodb

在laravel中使用mongodb

作者: Luwnto | 来源:发表于2016-08-01 23:55 被阅读2335次

    环境准备

    安装mongodb mongodb安装教程

    安装php-mongodb扩展 php-mongodb扩展安装教程

    安装laravel-mongodb

    获取jenssegers/mongodb

    composer require jenssegers/mongodb
    

    在config/app.php中注册服务

    Jenssegers\Mongodb\MongodbServiceProvider::class,
    

    起个别名

    'Mongo'     => Jenssegers\Mongodb\MongodbServiceProvider::class,
    

    修改数据库配置文件config/database.php中

    添加mongodb的数据库的信息:
    'mongodb' => [    
            'driver'   => 'mongodb',    
            'host'     => 'localhost',    
            'port'     => 27017,    
            'database' => 'mydb',    
            'username' => '',    
            'password' => '',
    ],
    
    'default' => env('DB_CONNECTION', 'mysql'),
    
    改成:
    
    'default' => env('DB_CONNECTION', 'mysql'),
    

    开始使用

    使用查询构造器方式

    新建一个UserController.php控制器

    php artisan make:controller UserController
    

    代码如下

    use DB;   //引用数据库
    
    class MongoController extends Controller{
        pubulic function index(){
            DB::collection('users')               //选择使用users集合
                  ->insert([                          //插入数据
                          'name'  =>  'tom', 
                          'age'     =>   18
                      ]);
        }
         
        $res = DB::collection('users')->all();  //查询所有数据
        dd($res);                                            //打印数据
    }
    

    设置好路由之后就可以访问测试了

    如果你没有修改默认的数据库配置(默认还是mysql),那么你在使用mongodb的时候就要指定使用mongodb了

    例:

    use DB;   //引用数据库
    
    class MongoController extends Controller{
        pubulic function index(){
            DB::connection('mongodb')       //选择使用mongodb
                  ->collection('users')           //选择使用users集合
                  ->insert([                          //插入数据
                          'name'  =>  'tom', 
                          'age'     =>   18
                      ]);
        }
         
        $res = DB::connection('mongodb')->collection('users')->all();   //查询所有数据
        dd($res);                                            //打印数据
    }
    

    有关查询构造器的使用和mysql的方式是一样的,参照laravel文档查询构造器

    使用Eloquent模型

    在config/app.php配置文件中配置mongodb的Eloquent类的别名

    'Moloquent' => 'Jenssegers\Mongodb\Eloquent\Model',
    

    新建一个User.php的Model类

    php artisan make:model User
    

    代码如下:

    <?php
        namespace App;
        use Moloquent;
        use DB;
    
        class Users extends Moloquent{    
            protected $connection = 'mongodb';  //库名    
            protected $collection = 'users';     //文档名    
            protected $primaryKey = '_id';    //设置id    
            protected $fillable = ['id', 'name', 'phone'];  //设置字段白名单
        }
    

    在UserController.php控制器中这样使用

    <?phpnamespace 
        App\Http\Controllers;
        use App\Users;    //引入Users模型
    
        class MongoController extends Controller{
            public function index(){
            Users::create([                      //插入数据
                'id'     =>1,
                'name'   =>'tom',
                'phone'  =>110]);
            }
    
            dd(Users::all());          //查询并打印数据
        }

    相关文章

      网友评论

      • 敢死队111:貌似Eloquent模型是无法自动加载到Moloquent的
      • qiuzhaokun:网络上都是这个版本,错的都一样
        Watts_:哪里错了?

      本文标题:在laravel中使用mongodb

      本文链接:https://www.haomeiwen.com/subject/esiijttx.html