PHP操作mongodb:



PHP 要操作mongodb须要打模块

官网能够下载:http://pecl.php.net/package/mongo 下载



mongodb设置成用户授权的启动方式



php手冊没有些用户授权方式登陆的方法:

conn.php

<?

php

$conn = new Mongo("mongodb://user1:123456@localhost:27017/test"); //用户授权链接mongodb test数据库

$db = $conn->test;

?>



find.php

<?php

include "conn.php";

$c1 = $db->c1;    //操作c1集合



//因为php里面不能直接用json

//db.c1.find({name:"user1"});   不能这么玩

//{name:"user1"} == array("name"=>"user1")   用这样的形式

//[1,2] == array(1,2);

//{} == array()



$arr=array();

$rst = $c1->find($arr);

foreach($rst as $val){

echo "<pre>";

print_r($val['name']);  //取id的话  得"_id"

}





样例2:指定值查询

$arr = array("name"=>"user1");  //查询nam=user1的

$rst = $c1->find($arr);

foreach($rst as $val){

echo "<pre>";

$fis = $val['_id'];

print_r($val);  

echo "<a href='user.php?

fid={$fid}'></a>";   //你会发现fid传到user.php的时候变成字符串了。怎么解决?

//user.php   依据_id查mongodb相应的数据

<?php

include "conn.php";

$c1 = $db->c1;

$oid= new MongoId($_GET['fid']); 用这个转一下

var_dump($oid);  //还是Object,不转的话就是string类型



$arr = array("_id"=>"$oid");  

$rst = $c1->find($arr);

foreach($rst as $val){

echo "<pre>";

print_r($val); 

}

?>

}





样例3:添加

include "conn.php";

$c1 = $db->c1;

//db.c1.insert({"name"=>"user3",age:30,"sex"=>"nan"});

$arr = array("name"=>"user3","age"=>30,"sex"=>"nan");

if($c1->insert($arr))

echo '成功';

else

echo '失败';









样例4:删

include "conn.php";

$c1 = $db->c1;

//db.c1.remove({"name"=>"user2"});

$arr = array("name"=>"user2");

if($c1->remove($arr))

echo '删除成功';

else

echo '删除失败';









样例4:改

include "conn.php";

$c1 = $db->c1;

//db.c1.update({"name"=>"user2"},{$set:{age:20,sex:"nan"}}); 添加字段

$sarr = array("name"=>"user2");

$darr = array('$set'=>array('sex'=>'nan','age'=>24));

$opts = array('upsert'=>0,'multiple'=>1);

if($c1->update($sarr,$darr,$opts))  //php里面的update仅仅能传3个參数

echo '更改成功';

else

echo '更改失败';



//关闭

$conn->close();

?

>

PHP操作MongoDB数据库具体样例介绍(增、删、改、查) (六)的更多相关文章

  1. 怎样从C#中打开数据库并进行 增 删 改 查 操作

    首先 在C#中引用数据库的操作! (因为我们用的是SQLserver数据库,所以是SqlClient) using System.Data.SqlClient; 1:要实现对数据库的操作,我们必须先登 ...

  2. 简单的php数据库操作类代码(增,删,改,查)

    这几天准备重新学习,梳理一下知识体系,同时按照功能模块划分做一些东西.所以.mysql的操作成为第一个要点.我写了一个简单的mysql操作类,实现数据的简单的增删改查功能. 数据库操纵基本流程为: 1 ...

  3. Java操作MongoDB:连接&增&删&改&查

    1.连接 ①方式一 MongoClientOptions.Builder builder = MongoClientOptions.builder(); //可以通过builder做各种详细配置 Mo ...

  4. Django(十)模型:django模型类对数据库的:增/删/改/查、自关联、管理器、元选项(指定表名)

    一.插入.更新和删除 调用一个模型类对象的save方法的时候就可以实现对模型类对应数据表的插入和更新. 调用一个模型类对象的delete方法的时候就可以实现对模型类对应数据表数据的删除. 二.自关联 ...

  5. MongoDB增 删 改 查

    增 增加单篇文档 > db.stu.insert({sn:'001', name:'lisi'}) WriteResult({ "nInserted" : 1 }) > ...

  6. django单表操作 增 删 改 查

    一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...

  7. php5.4以上 mysqli 实例操作mysql 增,删,改,查

    <?php //php5.4以上 mysqli 实例操作mysql header("Content-type:text/html;charset=utf8"); $conn ...

  8. python_操作MySQL 初解 之__<类方法调用并 增-删-改-查>

    文件一: 调用(sqls文件) # 导入模块 import pymysql from sqls import * # 创建类 class KaoShi(object): # 初始化 def __ini ...

  9. NodeJs连接操作MongoDB数据库

    NodeJs连接操作MongoDB数据库 一,介绍 MongoDB是一种文档导向数据库管理系统,由C++撰写而成.介绍如何使用 Node.js 来连接 MongoDB,并对数据库进行操作. Mongo ...

随机推荐

  1. NNVM代码阅读

    op.h #define DMLC_ATTRIBUTE_UNUSED __attribute__((unused)) __attribute__((unused)):通常,如果声明了某个变量,但从未对 ...

  2. winform WebBrowser如何修改使用默认的IE浏览器版本

    在搜了一些相关资料原来WebBrowser使用的是IE的兼容模式进行浏览(IE7模式). 建议:先添加注册表中,然后使用注册表编辑器导出功能,产生reg注册文件:方便日后使用. Winform  We ...

  3. AS3.0纯代码编写的两款loading效果

    AS3.0纯代码编写的两款loading效果 效果一 效果二 代码很简单,实现的原理一样,只不过矩形用到了Matrix类,对注册点进行了调整,效果可用于视频播放器缓冲时的loading效果,下面看代码 ...

  4. BOOST 实用手册(摘录自校友博客)

    1. 序言 现在学的东西很容易忘记,写这篇文章的目的是能让我在需要时快速找回当时的感觉.  Let's BOOST THE WORLD . 2. 编译:VC2005注意 在 属性->C/C++- ...

  5. Boost::Lexical_cast 的使用

    .C++代码 #include <boost/lexical_cast.hpp> #include <iostream> int main() { using boost::l ...

  6. Win8安装程序出现2502、2503错误解决方法

    我是在安装VMware virtualbox的时候遇到的这个问题,上网百度了一下发现这是个在win8系统上安装程序时才会遇到的. 究其原因这个问题还是由于权限问题导致的,解决方法如下: 1,ctrl+ ...

  7. Hibernate异常:Unable to locate appropriate constructor on class

    异常信息:org.hibernate.hql.ast.QuerySyntaxException: Unable to locate appropriate constructor on class o ...

  8. Silverlight 安装失败 提示 消息 ID 1603 的解决方法

    消息 ID: 1603 安装过程中出现错误.请执行以下步骤 原因是在以前安装过silverlight,没有安装成功或者没有彻底卸载干净,遗留了一些文件,尤其是安装时突然中断的时候会出现这个问题. 解决 ...

  9. 云计算之路-试用Azure:搭建自己的内网DNS服务器

    之前我们写过一篇博文谈到Azure内置的内网DNS服务器不能跨Cloud Service,而我们的虚拟机部署场景恰恰需要跨多个Cloud Service,所以目前只能选择用Azure虚拟机搭建自己的内 ...

  10. STL_算法_区间的比較(equal、mismatch、 lexicographical_compare)

    C++ Primer 学习中.. . 简单记录下我的学习过程 (代码为主) //全部容器适用 equal(b,e,b2)       //用来比較第一个容器[b,e)和第二个容器b2开头,是否相等 e ...