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. express路由和中间件

    路由 简单来说,express路由就是用来处理一些请求,响应一些url地址. var express = require('express'); var app = express(); app.ge ...

  2. codevs 1349 板猪的火车票

    1349 板猪的火车票  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题目描述 Description 奸商zn(请勿对号入座)开办了一家火车公司,弱弱的板猪 ...

  3. HDU 5289 Assignment rmq

    Assignment 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5289 Description Tom owns a company and h ...

  4. TDiocpCoderTcpServer 使用

    TDiocpCoderTcpServer 使用 uses diocp_coder_tcpServer,utils_zipTools,diocp_tcp_server,diocp_task // 创建T ...

  5. jQuery:validate添加自定义验证

    jQuery.validator.addMethod添加自定义的验证规则 addMethod:name, method, message 简单实例:单个验证的添加 <!DOCTYPE html ...

  6. JavaScript -- 清除缓存

    在客户端有一个HTML文件,用来提交输入信息,问题在于:每次按刷新时,发觉并不是整个页面重新被装载,好似是缓存中. 因为文本框中仍出现上次输入的值,只有在地址栏中按回车整个页面才重新装载,应当怎样避免 ...

  7. Openshift部署Zookeeper和Kafka

    部署Zookeeper github网址 https://github.com/ericnie2015/zookeeper-k8s-openshift 1.在openshift目录中,首先构建imag ...

  8. etcd,Docker问题汇总

    单节点etcd publish error 正在愉快的进行jenkins流程,突然发现etcd连接不上去了.重新reboot后发现日志publish error Oct :: k8s-master e ...

  9. [Java]利用javax.swing.Timer类在窗口上实现动画效果

    javax.swing.Timer类在创建时需要指定时间间隔和定时器到时间需要执行的动作,即ActionListener. Timer timer = new Timer(100, taskPerfo ...

  10. Android应用内使用新浪微博SDK发送微博(不调用微博客户端)

    需求 手头的一个应用需要添加分享到新浪微博的功能,这个功能在现在的应用上是非常的普遍的了. 分享到新浪微博,其实就是发送一条特定内容的微博,所以需要用到新浪微博SDK了. 微博SDK SDK的下载地址 ...