php7 laravel mongodb,在 Laravel 中使用 MongoDB

环境准备

安装 Laravel-MongoDB

推荐组件

composer require jenssegers/mongodb

注册服务

Jenssegers\Mongodb\MongodbServiceProvider::class,

添加 Facades

'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', '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')->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); //打印数据

}

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

Eloquent 模型

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

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

新建一个 User.php 的 Model 类

php artisan make:model User

参考代码

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 控制器中这样使用

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()); //查询并打印数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值