在Laravel中使用MongoDB的方法示例
时间:2022-07-27
本文章向大家介绍在Laravel中使用MongoDB的方法示例,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
MongoDB实用场景
- 产品用户访问日志,点击埋点统计信息
- 业务系统环境参数配置信息
- 业务系统运行时日志,如laravel.log,nginx.log
使用Homebrew在macoOS安装MongoDB PHP Driver
在macOS中,MongoDB 扩展已经从Homebrew仓库中移除,需要通过pecl安装此扩展。
$ 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扩展安装位置。
...
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文件
touch /usr/local/etc/php/7.2/conf.d/ext-mongodb.ini
将mongodb.so扩展写入该文件
[mongodb]
extension=/usr/local/Cellar/php@7.2/7.2.19/pecl/20170718/mongodb.so
同时在php.ini中移除mongodb.so扩展
extension="mongodb.so" // remove
extension="php_mongodb.so" // remove
重启一下PHP
sudo brew service restart --all
查看是否安装成功
php -m|grep mongodb
在Laravel中使用MongoDB
使用Composer创建一个Laravel项目
composer create-project --prefer-dist laravel/laravel laravel-mongodb-exploer -vvv
成功后,再安装Laravel-MongoDB扩展
composer require jenssegers/mongodb -vvv
按照扩展文档说明,我们添加一个MongoDB数据库连接
//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
./mongo
使用show dbs查看已有数据库
show dbs;
admin 0.000GB
config 0.000GB
local 0.000GB
viewers 0.000GB
如果没有发现viewers,则创建该数据库。注意只有viewers中存在collection时, 上面结果才会显示viewers
use viewers;
使用数据库后,需要创建colleciton
db.ad_clicks.insert({"ip":"201.35.63.14", "ad_index": 3, "created_at": "2019-06-10 11:34:12"})
使用find查询记录
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集合所有记录
DB::connection('mongodb')- table('ad_clicks')- get()
查询单个记录
DB::connection('mongodb')- collection('ad_clicks')- find('5cf71b34e14620598643d23b')
修改某个记录
DB::connection('mongodb')- collection('ad_clicks')- where('_id', '5cf71b34e14620598643d23b')- update(['ad_index'= 2]);
在Laravel ORM中查询MongoDB
在项目中,创建一个Model
php artisan make:model Models/AdClick
修改继承父类和数据库连接,AdClick.php
...
use JenssegersMongodbEloquentModel;
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中,插入数据
AppModelsAdClick::create(['ip' = '31.42.4.14', 'ad_index' = 4, 'created_at' = '2019-06-10 18:10:01', 'ip2long' = ip2long('31.42.4.14')]);
统计访问数据
AppModelsAdClick::where('ip', '31.42.4.14')- count()
以上就是本文的全部内容,希望对大家的学习有所帮助。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 搭建高可用的Replication集群归档大量的冷数据
- Python 技术篇-文件操控:文件的移动和复制
- Python发邮件脚本,Python调用163邮箱SMTP服务实现邮件群发
- 为PXC集群引入Mycat并构建完整的高可用集群架构
- Python3 字典
- 安装Percona Server数据库(in CentOS 8)
- Python 基础篇-正斜杠("/")和反斜杠("")的用法
- 在CentOS8下搭建PXC集群
- Python 基础篇-相对路径、绝对路径的写法
- Python3 元组
- 关于MySQL的基准测试
- Python 技术篇-操作excel,对excel进行读取和写入
- Mycat 整合 MySQL 8.x 踩坑实践
- Python 技术篇-xlwt库不新建,直接读取已存在的excel并写入
- Python3 列表