在laravel中使用mongodb

环境准备

安装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());          //查询并打印数据
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原文链接 必备品 文档:Documentation API:API Reference 视频:Laracasts ...
    layjoy阅读 8,623评论 0 121
  • 必备品文档:DocumentationAPI: API Reference视频:Laracasts速查表:Lara...
    ethanzhang阅读 5,762评论 0 68
  • 配置 修改config/database.php在connection数组中添加mongodb的配置信息,如下 '...
    jooohnny阅读 8,459评论 3 8
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,868评论 18 139
  • 领班眼中的她—葛丽 “靠的越近,走的越远” 走过往昔,奋斗的汗水...
    Tinaluting阅读 363评论 0 0