前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >在Laravel中使用MongoDB的方法示例

在Laravel中使用MongoDB的方法示例

作者头像
砸漏
发布2020-10-20 14:36:53
1.4K0
发布2020-10-20 14:36:53
举报
文章被收录于专栏:恩蓝脚本

MongoDB实用场景

  • 产品用户访问日志,点击埋点统计信息
  • 业务系统环境参数配置信息
  • 业务系统运行时日志,如laravel.log,nginx.log

使用Homebrew在macoOS安装MongoDB PHP Driver

在macOS中,MongoDB 扩展已经从Homebrew仓库中移除,需要通过pecl安装此扩展。

代码语言:javascript
复制
$ sudo pecl install mongodb -v
...

Build process completed successfully
Installing '/usr/local/Cellar/php@7.2/7.2.19/pecl/20170718/mongodb.so'
install ok: channel://pecl.php.net/mongodb-1.5.4
Extension mongodb enabled in php.ini

在项目中,使用phpinfo() 查询PHP扩展安装位置。

代码语言:javascript
复制
...
Configuration File (php.ini) Path  /usr/local/etc/php/7.2
Loaded Configuration File  /usr/local/etc/php/7.2/php.ini
Scan this dir for additional .ini files  /usr/local/etc/php/7.2/conf.d
Additional .ini files parsed  /usr/local/etc/php/7.2/conf.d/ext-opcache.ini, /usr/local/etc/php/7.2/conf.d/php-memory-limits.ini
....

按照ext-opcache.ini配置,创建一个ext-mongodb.ini文件

代码语言:javascript
复制
touch /usr/local/etc/php/7.2/conf.d/ext-mongodb.ini

将mongodb.so扩展写入该文件

代码语言:javascript
复制
 [mongodb]
 extension=/usr/local/Cellar/php@7.2/7.2.19/pecl/20170718/mongodb.so

同时在php.ini中移除mongodb.so扩展

代码语言:javascript
复制
extension="mongodb.so" // remove
extension="php_mongodb.so" // remove 

重启一下PHP

代码语言:javascript
复制
sudo brew service restart --all

查看是否安装成功

代码语言:javascript
复制
php -m|grep mongodb

在Laravel中使用MongoDB

使用Composer创建一个Laravel项目

代码语言:javascript
复制
composer create-project --prefer-dist laravel/laravel laravel-mongodb-exploer -vvv

成功后,再安装Laravel-MongoDB扩展

代码语言:javascript
复制
composer require jenssegers/mongodb -vvv

按照扩展文档说明,我们添加一个MongoDB数据库连接

代码语言:javascript
复制
//database.php
...
'mongodb' =  [
      'driver'  =  'mongodb',
      'host'   =  env('MONGODB_HOST', 'localhost'),
      'port'   =  env('MONGODB_PORT', 27017),
      'database' =  env('MONGODB_DATABASE'),
      'username' =  env('MONGODB_USERNAME'),
      'password' =  env('MONGODB_PASSWORD'),
      'options' =  [
        'database' =  'admin' // sets the authentication database required by mongo 3
      ]
    ],
...
 
 
//.env
... 
MONGODB_HOST=127.0.0.1
MONGODB_PORT=27017
MONGODB_DATABASE=viewers
...

命令行创建MongoDB数据库

macOS中,在命令行执行mongo开启MongoDB Shell

代码语言:javascript
复制
./mongo

使用show dbs查看已有数据库

代码语言:javascript
复制
show dbs;

admin  0.000GB
config  0.000GB
local  0.000GB
viewers 0.000GB

如果没有发现viewers,则创建该数据库。注意只有viewers中存在collection时, 上面结果才会显示viewers

代码语言:javascript
复制
use viewers;

使用数据库后,需要创建colleciton

代码语言:javascript
复制
db.ad_clicks.insert({"ip":"201.35.63.14", "ad_index": 3, "created_at": "2019-06-10 11:34:12"})

使用find查询记录

代码语言:javascript
复制
  db.ad_clicks.find()
{ "_id" : ObjectId("5cf71b34e14620598643d23b"), "ip" : "201.34.46.3", "ad_index" : "2", "created_at" : "2019-06-05 11:34:53" }
{ "_id" : ObjectId("5cf71d3de14620598643d23d"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 11:11:45" }
{ "_id" : ObjectId("5cf71d3ee14620598643d23e"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 11:11:45" }
{ "_id" : ObjectId("5cf71d44e14620598643d23f"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 11:11:45" }
{ "_id" : ObjectId("5cf71d45e14620598643d240"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 12:34:12" }
{ "_id" : ObjectId("5cfe28823316506991c41786"), "ip" : "201.35.63.14", "ad_index" : 3, "created_at" : "2019-06-10 11:34:12" }

在Laravel DB中查询MongoDB

使用了Laravel-MongoDB扩展,可以基于Eloquent与Query Builder操作MySQL一样的数据php artisan thinker

查询ad_clicks集合所有记录

代码语言:javascript
复制
DB::connection('mongodb')- table('ad_clicks')- get()

查询单个记录

代码语言:javascript
复制
DB::connection('mongodb')- collection('ad_clicks')- find('5cf71b34e14620598643d23b')

修改某个记录

代码语言:javascript
复制
DB::connection('mongodb')- collection('ad_clicks')- where('_id', '5cf71b34e14620598643d23b')- update(['ad_index'= 2]);

在Laravel ORM中查询MongoDB

在项目中,创建一个Model

代码语言:javascript
复制
php artisan make:model Models/AdClick

修改继承父类和数据库连接,AdClick.php

代码语言:javascript
复制
...
use Jenssegers\Mongodb\Eloquent\Model;

class AdClick extends Model
{
  protected $connection = 'mongodb';
 
   /**
   * The attributes that are mass assignable.
   *
   * @var array
   */
  protected $fillable = [];

  /**
   * The attributes that aren't mass assignable.
   *
   * @var array
   */
  protected $guarded = [];
}

继续在Thinker中,插入数据

代码语言:javascript
复制
App\Models\AdClick::create(['ip' =  '31.42.4.14', 'ad_index' =  4, 'created_at' =  '2019-06-10 18:10:01', 'ip2long' =  ip2long('31.42.4.14')]);

统计访问数据

代码语言:javascript
复制
App\Models\AdClick::where('ip', '31.42.4.14')- count()

以上就是本文的全部内容,希望对大家的学习有所帮助。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档