在config/database.php添加mongoDB数据库配置信息:
// 更多的数据库配置信息'mongodb'=>[// 数据库类型'type'=> 'mongo',// 服务器地址'hostname'=> '127.0.0.1',// 数据库名'database'=> 'test',// 用户名'username'=> '',// 密码'password'=> '',// 端口'hostport'=> '27017',// 数据库连接参数'params'=> [],// 数据库调试模式'debug' => env('database.debug', true),// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)'deploy'=> 0,// 数据库读写是否分离 主从式有效'rw_separate' => false,// 监听SQL'trigger_sql' => true,// 读写分离后 主服务器数量'master_num'=> 1,// 指定从服务器序号'slave_no'=> '',// 是否严格检查字段是否存在'fields_strict' => true,// 是否需要断线重连'break_reconnect' => false,// 字段缓存路径'schema_cache_path' => app()->getRuntimePath() . 'schema' . DIRECTORY_SEPARATOR,]
数据存入和读取的代码:
Db::connect('mongodb')->table('one')->insert(['name'=>123,'age'=>18]);$res = Db::connect('mongodb')->table('one')->select();dd($res);
效果:
补充一点mongoDB的知识:
mongoDB使用场景:
实时读取,对速度有要求,读取快
数据量大,并且数据保存价值不大,比如说文章的评论,尽管有数据持久化,但仍有丢失风险
不要求使用事务,不支持事务
mongoDB使用案例:
京东,存储商品信息,和关注功能.
赶集网,记录pv浏览计数
奇虎360,每天接受200亿次的查询
百度云,存储500亿条关于文件源信息的记录.
CERN粒子物理研究所,存储大型强子对撞机的数据
mongoDB和Redis的区别:
内存管理机制:Redis数据全部存储在内存,定期写入磁盘,当内存不够是,可以选择指定的LRU算法删除数据。Mongodb数据存在内存上,由Linux系统mmap实现,当内存不够时,只将热点数据放入内存,其他数据存在磁盘。
数据结构:Redis支持多种数据结构,包括Hash、set、list等。Mongodb支持比较单一,但支持丰富的数据表达,索引,最类似于关系型数据库,支持的查询语言比较丰富。