• 在 Laravel 中使用 MongoDB


    安装 Laravel-MongoDB

    https://github.com/jenssegers/laravel-mongodb/blob/master/README.md

    推荐组件

    composer require jenssegers/mongodb
    

    注册服务

    如果您的Laravel版本没有自动加载软件包,请将服务提供商添加到config/app.php:

    在 config/app.php 中的 providers 中添加如下配置:  

    JenssegersMongodbMongodbServiceProvider::class,
    

    添加 Facades

    在 config/app.php 中的 aliases 中添加别名:  

    'Mongo'     => JenssegersMongodbMongodbServiceProvider::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', 'mongodb'),
    

    使用篇

    查询构造器

    // 建立一个 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')->get();  //查询所有数据
        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);                                            //打印数据
    }
    

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

    Eloquent 模型

    • 在 config/app.php 配置文件中配置 MongoDB 的 Eloquent 类的别名
     'Moloquent' => 'JenssegersMongodbEloquentModel',
    
    • 新建一个 User.php 的 Model 类
    php artisan make:model User
    
    • 参考代码
    <?php
        namespace App;
        use JenssegersMongodbEloquentModel as Moloquent; 
        use DB;
    
        class Users extends Moloquent{    //继承的不是普通的model,而是Mongo中的Model
            protected $connection = 'mongodb';  //使用mongodb连接   
            protected $collection = 'users';     //文档名    
            protected $primaryKey = '_id';    //设置id    
            protected $fillable = ['id', 'name', 'phone'];  //设置字段白名单
        }
    
    • 在 UserController.php 控制器中这样使用
    <?phpnamespace 
        AppHttpControllers;
        use AppUsers;    //引入Users模型
    
        class MongoController extends Controller{
            public function index(){
            Users::create([                      //插入数据
                'id'     =>1,
                'name'   =>'tom',
                'phone'  =>110]);
            }
    
            dd(Users::all());          //查询并打印数据
    
  • 相关阅读:
    php使用redis的有序集合zset实现延迟队列
    php使用redis的几种常见方式和用法
    redis缓存雪崩,缓存穿透,缓存击穿的解决方法
    php操作redis数据库方法总结
    mysql 悲观锁与乐观锁的理解
    OAuth2.0 协议的理解
    windows下的mongodb安装与配置
    node.js中对 redis 的安装和基本操作
    node.js中对 mysql 进行增删改查等操作和async,await处理
    node.js中 koa 框架的基本使用方法
  • 原文地址:https://www.cnblogs.com/niuben/p/13718138.html
Copyright © 2020-2023  润新知