laravel.log
,nginx.log
在macOS中,MongoDB 扩展已经从Homebrew仓库中移除,须要经过pecl安装此扩展。php
$ 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扩展安装位置。nginx
...
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
文件laravel
touch /usr/local/etc/php/7.2/conf.d/ext-mongodb.ini
复制代码
将mongodb.so
扩展写入该文件sql
[mongodb]
extension=/usr/local/Cellar/php@7.2/7.2.19/pecl/20170718/mongodb.so
复制代码
同时在php.ini
中移除mongodb.so
扩展mongodb
extension="mongodb.so" // remove
extension="php_mongodb.so" // remove
复制代码
重启一下PHP数据库
sudo brew service restart --all
复制代码
查看是否安装成功bash
php -m|grep mongodb
复制代码
使用Composer
建立一个Laravel项目composer
composer create-project --prefer-dist laravel/laravel laravel-mongodb-exploer -vvv
复制代码
成功后,再安装Laravel-MongoDB扩展ui
composer require jenssegers/mongodb -vvv
复制代码
按照扩展文档说明,咱们添加一个MongoDB数据库链接this
//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
...
复制代码
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-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]);
复制代码
在项目中,建立一个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()
复制代码