开发环境

php版本:7.0.10

mongodb版本:1.5

开发框架:tp5

数据库工具:navicat12formongodb

可以参考的外部文件链接

tp5中mongodb的扩展说明:https://www.kancloud.cn/manual/thinkphp5_1/354135

一、 与mysql的不同之处

1、集合相当于是表的性质,但是没有字段的维度

2、在mongodb中,字段名是根据插入数据时的KEY自动生成,不需要提前建好

3、在mongodb中,一条文档指是就是一条纪录

二、mongodb操作心得

1、创建集合

2、操作文档

(1)新增文档

php代码:

public function addUser() // 控制器测试文件下的方法

{

$user_model = model('User');

$data = array(

'name'=>uniqid(time(),1),

'age'=>rand(0,2),

'time'=>time(),

);

$user_model->addUser($data);

}

/**

* 添加用户

* @param type $data

* @return type

*/

public function addUser($data) // 模型文件

{

return db('user')->insert($data);

}

工具视图:

_id是自动生成的自增长ID

(2)查询单条文档

public function getUserIofo(){  // 控制器测试文件下的方法

$user_model = model('User');

$id = '5d91a751a374a412e800074a';

$where = array('_id'=>$id);

$info = $user_model->getUserIofo($where);

var_dump($info);die;

}

/**

* 根据条件查询单条文档

* @param $condition

* @return array|false|\PDOStatement|string|Model

* @throws \think\db\exception\DataNotFoundException

* @throws \think\db\exception\ModelNotFoundException

* @throws \think\exception\DbException

*/

public function getUserIofo($condition){  // 模型文件

return db('user')->where($condition)->find();

}

打印出来的结果:

F:\wamp64\www\xxxxx\application\index\controller\Test.php:47:array (size=4)   '_id' =>      object(MongoDB\BSON\ObjectId)[22]       public 'oid' => string '5d91a751a374a412e800074a' (length=24)   'name' => string '15698266415d91a751313156.63813749' (length=33)   'age' => int 0   'time' => int 1569826641

在tp5中,系统特意增加一个配置

// 强制把_id转换为id

'pk_convert_id'  => true,

增加后,出来的结果就是下面这样的

F:\wamp64\www\xxxxx\application\index\controller\Test.php:47:array (size=4)   'name' => string '15698266415d91a751313156.63813749' (length=33)   'age' => int 0   'time' => int 1569826641   'id' => string '5d91a751a374a412e800074a' (length=24)

(3)修改文档

php代码:

public function saveUser(){  // 控制器测试文件下的方法

$user_model = model('User');

$data = array(

'name'=>'fly',

);

$id = '5d91a751a374a412e800074a';

$where = array('id'=>$id);

$user_model->editUser($data,$where);

}

/**

* 更新文档

* @param type $data

* @param type $condition

* @return type

*/

public function editUser($data, $condition)   // 模型文件

{

return db('user')->where($condition)->update($data);

}

工具视图:

(4)删除文档

php代码:

public function deleteUser(){   // 控制器测试文件下的方法

$user_model = model('User');

$id = '5d91a751a374a412e800074a';

$where = array('id'=>$id);

$user_model->deleteUser($where);

}

/**

* 删除文档

* @param $condition

* @return int

* @throws \think\Exception

* @throws \think\exception\PDOException

*/

public function deleteUser($condition){    // 模型文件

return db('user')->where($condition)->delete();

}

工具视图:

三、操作总结

经过以上增、删、改、查的操作后,发现跟原来的TP5中db操作大同小异

我的mongoDb之旅(一)的更多相关文章

  1. 转载:MongoDB之旅(超赞,适合初学者)

    MongoDB是目前工作中经常使用到的NoSQL数据库. 本博客只记录相关理论知识和技巧,涉及到实践的部分都会单开Blog来记录实践过程. ------------------------------ ...

  2. 我的mongoDb之旅(二)

    题序:上一回,咱们简单的操作了一些增减改查的操作,这一次,再来进行一场奇妙之旅 一.案例讲解 (1).字段有值与没值时的单条数据 第一条数据title这个字段(mysql用久了,习惯这么叫了)是没有数 ...

  3. MongoDB安装并随windows开机自启

    MongoDB的官方下载站是http://www.mongodb.org/downloads,可以去上面下载最新的程序下来.在下载页面可以看到,对操作系统支持很全面,OS X.Linux.Window ...

  4. MongoDB在Windows下安装及配置

    第一步 下载MongoDB http://www.mongodb.org/downloads 第二步 解压到D:\mongodb\目录下,为了命令行的方便,可以把D:\mongodb\bin加到系统环 ...

  5. 在WIN7下安装运行mongodb 1)、下载MongoDB

    1).下载MongoDB http://downloads.mongodb.org/win32/mongodb-win32-i386-2.4.5.zip 下载Windows 32-bit版本并解压缩, ...

  6. mongodb学习(三) 安装和基本CRUD

    菜鸟啊...先吐槽一下自己 发现mongodb已经升级到2.6标准版了.  服务端最新安装方法: http://www.cnblogs.com/lzrabbit/p/3682510.html 一 准备 ...

  7. Node+Express+MongoDB+Socket.io搭建实时聊天应用实战教程(一)--MongoDB入门

    前言 本文并不是网上流传的多少天学会MongoDB那种全面的教程,而意在总结这几天使用MongoDB的心得,给出一个完整的Node+Express+MongoDB+Socket.io搭建实时聊天应用实 ...

  8. 简明 MongoDB 入门教程

    MongoDB 是免费开源的跨平台 NoSQL 数据库,命名源于英文单词 humongous,意思是「巨大无比」,可见开发组对 MongoDB 的定位.与关系型数据库不同,MongoDB 的数据以类似 ...

  9. 在WIN7下安装运行mongodb

    1).下载MongoDB http://downloads.mongodb.org/win32/mongodb-win32-i386-2.4.5.zip 下载Windows 32-bit版本并解压缩, ...

随机推荐

  1. Java入门指南-02 变量

    一.回顾上一篇讲到了常用的DOS命令.如何创建第一个程序.打印.注释与空白. 那么我们已经学会了使用System.out.println() 可以来输出一个值.进一步的,我们可以用它来显示简单的算术运 ...

  2. POJ2084 Game of Connections 卡特兰数 关于卡特兰数经典的几个问题

    Game of Connections Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 9128   Accepted: 44 ...

  3. spring boot使用AOP切面编程

    spring boot使用AOP 1.在pom文件中添加依赖: <!--spring boot aop切面--> <dependency> <groupId>org ...

  4. 新建项目中的fail和missing之类的问题

    首先必须要明白:每一个项目需要都要安装在本地仓库中去--->pom,war,jar无一例外 如果不安装会出现下面的错误: 解决的办法就是: 先clean后install项目,把他们安装到本地仓库 ...

  5. 使用Idea第一次创建一个Mavne工程时没有src目录

    在使用idea创建一个maven工程时没有src目录,可能出现的问题很多,我先把我自己的问题分享上来 因为没有src,可能是因为maven插件还没下载到本地仓库.maven插件的版本和jdk版本冲突或 ...

  6. 配置Linux使用LDAP用户认证

    配置Linux使用LDAP用户认证 本文首发:https://www.cnblogs.com/somata/p/LinuxLDAPUserAuthentication.html 我这里使用的是Cent ...

  7. 使用vitamio长时间播放崩溃的另类处理

    最近公司一个项目在公交站旁边弄一个 广告牌,上面是广告视频,下面是广告图片,都是无限轮播的.要求从早上6点到晚上11点不间断播放.剩余时间为关机状态. 图片部分还好说,就是viewpager弄一个无限 ...

  8. 操作系统原理之I/O设备管理(第六章上半部分下)

    五.I/O软件原理 输入输出软件的总体目标是将软件组织成一种层次结构 低层软件用来屏蔽硬件的具体细节 高层软件则主要是为用户提供一个简洁.规范的界面 设备管理的4个层次: 用户层软件 ->向系统 ...

  9. TCP/IP协议,TCP与平台通信,通讯协议压力测试(python)

    最近的项目来了一个需求,要求测试tcp网关通讯协议: 1.液压井盖通过TCP/IP TCP与平台通信: 2.硬件定期发送心跳包(10S)给平台,是平台与硬件保持长连接: 3.每台硬件有一个12字节的唯 ...

  10. kubernetes集群部署高可用Postgresql的Stolon方案

    目录 前言 ....前言 本文选用Stolon的方式搭建Postgresql高可用方案,主要为Harbor提供高可用数据库,Harbor搭建可查看kubernetes搭建Harbor无坑及Harbor ...