前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MongoDB学习系列(2)--使用PHP访问MongoDB

MongoDB学习系列(2)--使用PHP访问MongoDB

作者头像
八哥
发布2018-01-18 17:31:45
9180
发布2018-01-18 17:31:45
举报
文章被收录于专栏:快乐八哥

第一部分:介绍

在Windows上安装最新MongoDB步骤非常的简单,这里不做介绍。但是如果你安装的时候没有将MongoDB作为服务运行,每次你都要使用cmd切换到指定的目录下,然后在cmd中启动MongoDB服务,然后再使用另外一个cmd运行Javascript Shell。所以我自己创建了2个.bat文件来简化这个操作。

clip_image001
clip_image001

Run_MongoDB_Service.bat代码为:

代码语言:js
复制
d:
cd d:\mongodb\bin
mongod --dbpath d:\mongodb\data
Run_MongoDB.bat代码为:
d:
cd d:\mongodb\bin
mongo

我们使用Javascript Shell操作都在Run_MongoDB的命令框中进行。

第二部分:安装PHP Driver for MongoDB

安装步骤:

步骤1.进入网站http://docs.mongodb.org/ecosystem/drivers/php/ 根据步骤和提示下载最新PHP Driver。很多博客和帖子都介绍,都是把“php_mongo.dll”复制到php extension的目录中。其实下载文件如下图所示,不仔细的同学就要迷糊了,我只要一个dll,怎么给我下载了这么多文件,而且我也不知道选择哪个?

clip_image002
clip_image002

步骤2:我先将php_mongo-1.4.2-5.4-vc9.dll复制到php安装目录的ext中,5.4表明是我安装的PHP版本是5.4。所以大家要根据自己的安装类型选择正确的dll。nts:not thread safe。具体情况我也不明白,我安装php时候下载的是线程安全类型,所以复制就不要复制有nts结尾的dll。另外x86_64是说明安装MongoDB的版本支持64位。我安装的是32位,所以没有选择它。

步骤3:然后在php.ini添加了一行代码,引入php_mongo类库。

extension=php_mongo-1.4.2-5.4-vc9.dll

MongoDB for PHP Driver下载地址是存放在aws中s3上,访问速度还不错。

https://s3.amazonaws.com/drivers.mongodb.org/php/index.html

步骤4:检验php driver for MongoDB是否成功,我们只要新建一个测试页面。输入代码

<?php

echo phpinfo();

?>

如果页面出现下面结果,表明安装成功。

clip_image003
clip_image003

第三部分:使用PHP连接MongoDB示例程序

初学MongoDB的人都习惯使用JavaScript Shell来操作MongoDB。通俗易懂,是入门学习MongoDB最佳的方法。下面演示使用PHP连接MongoDB,然后往数据库里面插入一条数据。代码如下:

代码语言:javascript
复制
<?php
    /*echo phpinfo();*/
    $action=(!empty($_POST['btn_submit'])&&($_POST['btn_submit']==='Save'))?
    "save_article":
    "show_form";
    switch($action){
        case "save_article":
        try{
        $connection=new Mongo();
        //选择数据库
        $database=$connection->selectDB("myblogsite");
        //选择集合
        $collection=$database->selectCollection("articles");
        
        $article=array(
            'title'=>$_POST['title'],
            'content'=>$_POST['content'],
            'saved_at'=>new MongoDate()
        );
        //向集合插入记录
        $collection->insert($article);
        }catch(MongoConnectionException $e){
            die("Failed to connect the MongoDB" .$e->getMessage());
        }
        break;
        case "show_form":
        default:
        break;
    }
    
?>
<html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title>PHP Connect the MongoDB Demo</title>
    </head>
    <body>
        <?php if($action==='show_form'): ?>
        <!--显示提交表单-->
        <form action="<?php echo $_SERVER['PHP_SELF'] ?>" method="post">
            
            <div>
            <label for="title">Ttile:</label>
            <input type="text" name="title" id="title"/>
            </div>
            <div>
                <label for="content">Content:</label>
                <textarea name="content" id="content" cols="70" rows="10"></textarea>
            </div>
            <div>
                <input type="submit" value="Save" name="btn_submit" id="btn_submit"/>
            </div>
        </form>
        <?php else: ?>
        <!--显示提交成功内容-->
        <div>
            Article saved in MongoDB ._id:<?php echo $article['_id']; ?><br/>
            Blog title:<span><?php echo $article['title'];?></span>
                    <a href="test.php">Write another blog?</a>
                </div>
        <?php endif; ?>
    </body>
</html>

1.编辑界面

clip_image004
clip_image004

2.提交成功之后界面

clip_image005
clip_image005

最后我们可以使用JavaScript Shell查看刚插入成功的记录。截图如下:

clip_image006
clip_image006
代码语言:js
复制
<!-- .csharpcode, .csharpcode pre { 	font-size: small; 	color: black; 	font-family: consolas, "Courier New", courier, monospace; 	background-color: #ffffff; 	/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt  { 	background-color: #f4f4f4; 	width: 100%; 	margin: 0em; } .csharpcode .lnum { color: #606060; } -->
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2013-08-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档