在Laravel中使用MongoDB的方法示例
MongoDB实用场景
- 产品用户访问日志,点击埋点统计信息
- 业务系统环境参数配置信息
- 业务系统运行时日志,如laravel.log,nginx.log
使用Homebrew在macoOS安装MongoDBPHPDriver
在macOS中,MongoDB扩展已经从Homebrew仓库中移除,需要通过pecl安装此扩展。
$sudopeclinstallmongodb-v ... Buildprocesscompletedsuccessfully Installing'/usr/local/Cellar/php@7.2/7.2.19/pecl/20170718/mongodb.so' installok:channel://pecl.php.net/mongodb-1.5.4 Extensionmongodbenabledinphp.ini
在项目中,使用phpinfo()查询PHP扩展安装位置。
... ConfigurationFile(php.ini)Path/usr/local/etc/php/7.2 LoadedConfigurationFile/usr/local/etc/php/7.2/php.ini Scanthisdirforadditional.inifiles/usr/local/etc/php/7.2/conf.d Additional.inifilesparsed/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
sudobrewservicerestart--all
查看是否安装成功
php-m|grepmongodb
在Laravel中使用MongoDB
使用Composer创建一个Laravel项目
composercreate-project--prefer-distlaravel/laravellaravel-mongodb-exploer-vvv
成功后,再安装Laravel-MongoDB扩展
composerrequirejenssegers/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'//setstheauthenticationdatabaserequiredbymongo3 ] ], ... //.env ... MONGODB_HOST=127.0.0.1 MONGODB_PORT=27017 MONGODB_DATABASE=viewers ...
命令行创建MongoDB数据库
macOS中,在命令行执行mongo开启MongoDBShell
./mongo
使用showdbs查看已有数据库
showdbs; admin0.000GB config0.000GB local0.000GB viewers0.000GB
如果没有发现viewers,则创建该数据库。注意只有viewers中存在collection时,上面结果才会显示viewers
useviewers;
使用数据库后,需要创建colleciton
db.ad_clicks.insert({"ip":"201.35.63.14","ad_index":3,"created_at":"2019-06-1011:34:12"})
使用find查询记录
>db.ad_clicks.find() {"_id":ObjectId("5cf71b34e14620598643d23b"),"ip":"201.34.46.3","ad_index":"2","created_at":"2019-06-0511:34:53"} {"_id":ObjectId("5cf71d3de14620598643d23d"),"ip":"200.14.145.64","ad_index":1,"created_at":"2019-06-0411:11:45"} {"_id":ObjectId("5cf71d3ee14620598643d23e"),"ip":"200.14.145.64","ad_index":1,"created_at":"2019-06-0411:11:45"} {"_id":ObjectId("5cf71d44e14620598643d23f"),"ip":"200.14.145.64","ad_index":1,"created_at":"2019-06-0411:11:45"} {"_id":ObjectId("5cf71d45e14620598643d240"),"ip":"200.14.145.64","ad_index":1,"created_at":"2019-06-0412:34:12"} {"_id":ObjectId("5cfe28823316506991c41786"),"ip":"201.35.63.14","ad_index":3,"created_at":"2019-06-1011:34:12"}
在LaravelDB中查询MongoDB
使用了Laravel-MongoDB扩展,可以基于Eloquent与QueryBuilder操作MySQL一样的数据phpartisanthinker
查询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]);
在LaravelORM中查询MongoDB
在项目中,创建一个Model
phpartisanmake:modelModels/AdClick
修改继承父类和数据库连接,AdClick.php
... useJenssegers\Mongodb\Eloquent\Model; classAdClickextendsModel { protected$connection='mongodb'; /** *Theattributesthataremassassignable. * *@vararray */ protected$fillable=[]; /** *Theattributesthataren'tmassassignable. * *@vararray */ protected$guarded=[]; }
继续在Thinker中,插入数据
App\Models\AdClick::create(['ip'=>'31.42.4.14','ad_index'=>4,'created_at'=>'2019-06-1018:10:01','ip2long'=>ip2long('31.42.4.14')]);
统计访问数据
App\Models\AdClick::where('ip','31.42.4.14')->count()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。