在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 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中,插入数据
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')]);
统计访问数据
app\models\adclick::where('ip', '31.42.4.14')->count()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 红薯的做法有哪些呢
推荐阅读
-
关于C# 5.0 CallerMemberName CallerFilePath CallerLineNumber 在.NET4中的使用介绍方法
-
在PYQT5中QscrollArea(滚动条)的使用方法
-
接口对象的实例化在接口回调中的使用方法
-
在Python中定义和使用抽象类的方法
-
Android 在子线程中更新UI的几种方法示例
-
在Django中同时使用多个配置文件的方法
-
在Django的模型中添加自定义方法的示例
-
在Create React App中使用CSS Modules的方法示例
-
在PYQT5中QscrollArea(滚动条)的使用方法
-
关于C# 5.0 CallerMemberName CallerFilePath CallerLineNumber 在.NET4中的使用介绍方法