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. bootstrap中日历组件只显示年月

    大多数情况下日历组件我们使用的都是yyyy-mm-dd的日历格式,但是有时候需求不需要我们精确到日,而是最小单位到月份(yyyy-mm),网上找了很多方法,但是都没有我想要的效果,一些属性的设置都没有 ...

  2. [转] json字符串转换为JSONObject和JSONArray

    一.下载json 具体到http://www.json.org/上找java-json下载,并把其放到项目源代码中,这样就可以引用其类对象了 二.具体转化过程 //JSONObject String ...

  3. Codeforces Beta Round #3 A. Shortest path of the king 水题

    A. Shortest path of the king 题目连接: http://www.codeforces.com/contest/3/problem/A Description The kin ...

  4. YS动态口令系统接入流程

    动态口令是保护用户账户的一种常见有效手段,即用户进行敏感操作(比如登录)时,需要用户提供此动态生成的口令做二次身份验证,假设用户的口令被盗,如果没有动态口令,也无法进行登录或进行敏感操作,保护了用户的 ...

  5. GG同步到sqlserver报错一例 Invalid date format

    在将Oracle表同步到sqlserver时,在sqlserver端应用数据时,可能会遇到这个报错. 2014-05-17 17:20:24 WARNING OGG-01154 SQL error - ...

  6. bcp功能

    #include "MyBCP.h" #include "odbcss.h" //1,Allocate an environment handle and a ...

  7. FIREMONEY手机虚拟键盘遮挡的解决

    FIREMONEY手机虚拟键盘遮挡的解决 尝遍了网上人们提供的N种方法之后,发现还是老猫的方法才是彻底解决问题的办法. 老猫“不看后悔XXX”--->RAD10.2.3 Flying Wang ...

  8. Express极简实例

    假设已创建一个Express工程,否则请参考express工程环境准备 修改app.js var express = require('express'); var app = express(); ...

  9. Oracle 11gR2 RAC 数据库不能连接(ORA-12537: TNS:connection closed)的解决

        Oracle 11gR2 RAC 数据库不能连接(ORA-12537: TNS:connection closed)的解决 [oracle@rac01 ~]$ sqlplus /nolog S ...

  10. 从Cell的视图推出一个新的界面

    先写一个方法, 强制增加一个navigation的属性. 这样self就可以调出来navigation了 - (UINavigationController*)naviController { for ...