在 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
- 参考代码
<?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()); //查询并打印数据
PS
感谢关注「GitHub 热门」公众号,带你了解技术圈内热门新鲜事!
本作品采用《CC 协议》,转载必须注明作者和本文链接
本帖由系统于 6年前 自动加精
markdown 乱掉了
@Summer 我去...怎么变了....我改改
谢谢哈
@小小海 ...?
学习一下
@小小海 不客气哈,你也多分析分析让我们学习下
config/database.php 配置哪里 应该是改成 'default' => env('DB_CONNECTION', 'mongodb'),
Eloquent 部分
class Users extends Moloquent{
protected $connection = 'mongodb'; //库名
protected $collection = 'users'; //文档名
这里似乎写错了
collection应该代表的是集合
补充(170922)
目前Laravel-mongoDB稳定版本 v3.2.3在Laravel5.5下composer require 会报错
可以考虑
composer require jenssegers/mongodb v3.3.0-alpha
https://github.com/jenssegers/laravel-mong...
@Kurisu :+1:
我连接时间报错,是为什么呢?
Unauthorized: not authorized on zsfuaci to execute command { find: "test", filter: { name: "chenjiantan" }, limit: 1, $db: "zsfuaci", $readPreference: { mode: "primaryPreferred" }, lsid: { id: UUID("590af18b-e910-4864-9d3b-9d3f70dadbe3") } }
@Kurisu 您说protected $collection = 'users'; //文档名 写错了 应该怎么改呢 请教下
楼主你好,我laravel是5.4的怎么安装?
我链接数据库 protected $connection = 'mongodb'; mongodb也配置好了
但是出现错误 Call to a member function prepare() on null
如果用户模型继承了Moloquent 如何实现认证
执行命令 composer require jenssegers/mongodb 出现以下错误

我现在环境是php 7 lavarel5.5
如果你有同样问题可是使用这个命令
composer require jenssegers/mongodb ^3.3 -vvv
@zhaoyang365 看上面的提示,有版本约束的提示。
如果要删除laravel上的mongodb怎么办;一直提示Class/Mongodb not found
如果要在模型中给mongoDB数据库新增索引应该要怎么办呢?
能否打印mongodb的执行语句
楼主你好,laravel这个mongo拓展包
jenssegers/mongodb
,insert时候不支持加入参数我想加入一个
['ordered'=>false]
忽略一下已经存在的数据,需要怎么做呢?有这个查询的文档吗,查询所有数据之后再查询子集就出问题了。
请问如何查询时对字段进行别名处理?急急急
@DongXin 查出来之后再用集合处理一下,这样试试?
请问如何打印执行语句?使用DB::getQueryLog()无法获取
@DongXin 请问下你找到方法打印了吗
created_at字段包含时分秒,想对created_at的年月日分组该怎么操作?
请问具体的使用语法 和 mysql 的orm操作方法一样吗
请问laravel mongodb怎么分组查询?没有aggregate方法吗
'Mongo' 的Facade 貌似没有demo哦~~
laravel 版本 8.38
mongodb composer 扩展包版本
"jenssegers/mongodb": "^3.8",
执行示例代码报错
$res = DB::connection('mongodb')->collection('users')->all();
报错信息如下
Call to undefined method Jenssegers\Mongodb\Query\Builder::all()
改成 get 方法获取正常
$res = DB::connection('mongodb')->collection('users')->get();
其它方法示例
相关理解