首页 > 作文

在Laravel中使用MongoDB的方法示例

更新时间:2023-04-08 05:51:39 阅读: 评论:0

mongodb实用场景

产品用户访问日志,点击埋点统计信息业务系统环境参数配置信息业务系统运行时日志,如laravel.log,nginx.log

使用homebrew在macoos安装mongodb php driver

在macos中,mongodb 扩展已经从homebrew仓库中移除,需要通过pecl安装此扩展。

$ sudo pecl install mongodb -v...build process completed successfullyinstalling '/usr/local/cellar/php@7.2/7.2.19/pecl/20170718/mongodb.so'install ok: channel://pecl.php.net/mongodb-1.5.4extension mongodb enabled in php.ini

在项目中,使用phpinfo() 查询php扩展安装位置。

...configuration file (php.ini) path  /usr/local/etc/php/7.2loaded configu小学五年级体育教学计划ration file  /usr/local/etc/php/7.2/php.i道家学派的创始人niscan this dir for additional .ini files  /usr/local/etc/php/7.2/conf.dadditional .ini files pard  /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" // removeextension="php_mongodb.so" // remove 

重启一下php

sudo brew rvice restart --all

查看是否安装成功

php -m|grep mongodb

在laravel中使用mongodb

使用compor创建一个laravel项目

compor create-project --prefer-dist laravel/laravel laravel-mongodb-exploer -vvv

成功后,再安装laravel-mongodb扩展

compor require jensgers/mongodb -vvv

按照扩展文档说明,我们添加一个mongodb数据库连接

//databa.php...'mongodb' => [      'driver'  => 'mongodb',      'host'   => env('mongodb_host', 'localhost'),      'port'   => env('mongodb_port', 27017),      'databa' => env('mongodb_databa'),      'urname' => env('mongodb_urname'),      'password' => env('mongodb_password'),      'options' => [        'databa' => 'admin' // ts the authentication databa required by mongo 3      ]    ],...  //.env... mongodb_host=127.0.0.1mongodb_port=27017mongodb_databa=viewers...

命令行创上军校建mongodb数据库

macos中,在命令行执行mongo开启mongodb shell

./mongo

使用show dbs查看已有数据库

show dbs;admin  0.000gbconfig  0.000gblocal  0.000gbviewers 0.000gb

如果没有发现viewers,则创建该数据库。注意只有viewers中存在collection时, 上面结果才会显示viewers

u viewers;

使用数据库后,需要创建colleciton

db.ad_clicks.inrt({"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', '5cf71b34e14620598孔雀东南飞翻译643d23b')->update(['ad_index'=>2]);

在laravel orm中查询mongodb

在项目中,创建一个model

php artisan make:model models/adclick

修改继承父类和数据库连接,adclick.php

...u jensgers\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()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持www.887551.com。

本文发布于:2023-04-08 05:51:37,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/f7f16f9cad77c916350ab9f7613bdc16.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:在Laravel中使用MongoDB的方法示例.doc

本文 PDF 下载地址:在Laravel中使用MongoDB的方法示例.pdf

标签:数据库   创建一个   项目   数据
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图