在Laravel中使用MongoDB的方法示例
Laravel  /  管理员 发布于 7年前   201
MongoDB实用场景 使用Homebrew在macoOS安装MongoDB PHP Driver 在macOS中,MongoDB 扩展已经从Homebrew仓库中移除,需要通过pecl安装此扩展。 在项目中,使用phpinfo() 查询PHP扩展安装位置。 按照ext-opcache.ini配置,创建一个ext-mongodb.ini文件 将mongodb.so扩展写入该文件 同时在php.ini中移除mongodb.so扩展 重启一下PHP 查看是否安装成功 在Laravel中使用MongoDB 使用Composer创建一个Laravel项目 成功后,再安装Laravel-MongoDB扩展 按照扩展文档说明,我们添加一个MongoDB数据库连接 命令行创建MongoDB数据库 macOS中,在命令行执行mongo开启MongoDB Shell 使用show dbs查看已有数据库 如果没有发现viewers,则创建该数据库。注意只有viewers中存在collection时, 上面结果才会显示viewers 使用数据库后,需要创建colleciton 使用find查询记录 在Laravel DB中查询MongoDB 使用了Laravel-MongoDB扩展,可以基于Eloquent与Query Builder操作MySQL一样的数据php artisan thinker 查询ad_clicks集合所有记录 查询单个记录 修改某个记录 在Laravel ORM中查询MongoDB 在项目中,创建一个Model 修改继承父类和数据库连接,AdClick.php 继续在Thinker中,插入数据 统计访问数据 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。$ sudo pecl install mongodb -v...Build process completed successfullyInstalling '/usr/local/Cellar/[email protected]/7.2.19/pecl/20170718/mongodb.so'install ok: channel://pecl.php.net/mongodb-1.5.4Extension mongodb enabled in php.ini
...Configuration File (php.ini) Path /usr/local/etc/php/7.2Loaded Configuration File /usr/local/etc/php/7.2/php.iniScan this dir for additional .ini files /usr/local/etc/php/7.2/conf.dAdditional .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....
touch /usr/local/etc/php/7.2/conf.d/ext-mongodb.ini
[mongodb] extension=/usr/local/Cellar/[email protected]/7.2.19/pecl/20170718/mongodb.so
extension="mongodb.so" // removeextension="php_mongodb.so" // remove
sudo brew service restart --all
php -m|grep mongodb
composer create-project --prefer-dist laravel/laravel laravel-mongodb-exploer -vvv
composer require jenssegers/mongodb -vvv
//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.1MONGODB_PORT=27017MONGODB_DATABASE=viewers...
./mongo
show dbs;admin 0.000GBconfig 0.000GBlocal 0.000GBviewers 0.000GB
use viewers;
db.ad_clicks.insert({"ip":"201.35.63.14", "ad_index": 3, "created_at": "2019-06-10 11:34:12"})
> 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" }
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]);
php artisan make:model Models/AdClick
...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 = [];}
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()
您可能感兴趣的文章:
123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..路人 在
php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号