在 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());          //查询并打印数据												
											在 Laravel 中使用 MongoDB的更多相关文章
- 在Laravel中使用mongoDB
		
https://blog.csdn.net/weixin_38682852/article/details/80840678?utm_source=blogxgwz1 https://blog.csd ...
 - Laravel中的日志与上传
		
PHP中的框架众多,我自己就接触了好几个.大学那会啥也不懂啥也不会,拿了一个ThinkPHP学了.也许有好多人吐槽TP,但是个人感觉不能说哪个框架好,哪个框架不好,再不好的框架你能把源码读上一遍,框架 ...
 - laravel中日志为daily时如何设置最大保存天数
		
在laravel中,日志设置为daily时,默认保存七天的日志,超过则清除七天前的日志.可修改默认的设置,假如要保存30天的日志,则配置如下: 在配置文件config/app.php中添加如下代码: ...
 - laravel中的错误与日志
		
日志 laravel中的日志是基于monolog而封装的.laravel在它上面做了几个事情: 把monolog中的addInfo等函数简化成为了info这样的函数 增加了useFiles和useDa ...
 - laravel中的$request对象构造及请求生命周期
		
laravel应用程序中index.php是所有请求的入口.当用户提交一个form或者访问一个网页时,首先由kernel捕捉到该session PHP运行环境下的用户数据, 生成一个request对象 ...
 - cron以及在laravel中使用cron
		
yum install vixie-cron yum install crontabs /bin/systemctl restart crond.service #启动服务 /bin/systemct ...
 - Laravel中的队列处理
		
Laravel中的队列处理 队列介绍 为什么要有消息队?这里先对其进行一个简单的介绍,方便还不了解的同学理解.在面向对象里,有一个很简单的概念--消息传递,而消息队列就可以在它上面扩展一下,把它说的更 ...
 - 在Laravel中一步一步创建Packages
		
首先要看一下Laravel官方文档,这是最新4.2的文档,假设想看中文的话点击此处,基本一样.这个github上的库setup-laravel4-package,也是一步一步介绍怎样创建一个包.并关联 ...
 - Laravel 中使用 Redis 数据库
		
一.前言 Redis 是一个开源高效的键值对存储系统,它通常用作为一个数据结构服务器来存储键值对,它可以支持字符串.散列.列表.集合.有序集合. 1. 安装 predis/predis 在 Larav ...
 
随机推荐
- 0008SpringBoot中的spring.config.location对于运维的用处
			
在工作过程中,若项目已经打好包,application.properties中的配置文件已经不能修改,但是还是需要修改一些参数或者新增一些参数的情况下怎么办? 可以单独再定义一个配置文件,比如定义名称 ...
 - tp5.1下redis配置和使用
			
//1.config目录下新建redis.php <?php /** * Created by PhpStorm. * User: Administrator * Date: 2019/12/1 ...
 - DisplayModeProvider完成移动开发自动视图解析
			
MVC中新建视图命名:XXX.cshtml.XXX.mobile.cshtml:用手机访问会自动到xxx.mobile.cshtml 一.原理 MVC中是通过DisplayModeProvider实现 ...
 - KETTLE 更新表的两种方式-更新控件和sql更新 2种方式的实现比较
			
在实际工作中,我们有可能遇见只更新不插入的情况,可以由以下2种方式去实现: 1.更新控件 如下图所示,根据id字段,更新name和cjsj时间字段 该控件不足的地方是,用来查询关键值得字段不够灵活,一 ...
 - HR#4 题解
			
既然考这么差就来写题啦OTZ T1 猜结论?猜nm! 一直到考试结束都没猜出来=.=我就好奇别人如何猜出来的 我们来说DP(from ZBK) 设\(dp[i][j]\)表示胜or负 那我们来看一下代 ...
 - 000_linux之Ubuntu安装
			
今天2018/6/1 今天是六一儿童节,天气凉爽,心情挺好的.然后本着开开心心的心情,将前面忘记写linux的Ubuntu没安装的写一下,以后自己回来看就很方便了.使用的是白问网制作的ubuntu,假 ...
 - 应用webservice实现公网天气查询
			
1. wsdl网址:http://ws.webxml.com.cn/WebServices/WeatherWS.asmx?wsdl 2. URL:http://www.webxml.com.cn/zh ...
 - [HNOI2009]最小圈 分数规划 spfa判负环
			
[HNOI2009]最小圈 分数规划 spfa判负环 题面 思路难,代码简单. 题目求圈上最小平均值,问题可看为一个0/1规划问题,每个边有\(a[i],b[i]\)两个属性,\(a[i]=w(u,v ...
 - NVMe - NB的特性
			
翻译一下,纯粹是为了记住这些特性: NVMe provides the following benefits: ● Ultra-low latency 非常低的延迟 ● Very high throu ...
 - Doki Doki Literature Club ZOJ - 4035
			
Doki Doki Literature Club ZOJ - 4035 题解:其实就是简单排序输出就没了. #include <cstdio> #include <cstring& ...