Heim >Backend-Entwicklung >PHP-Tutorial >php与mongoDB操作示例详解_PHP教程

php与mongoDB操作示例详解_PHP教程

WBOY
WBOYOriginal
2016-07-13 10:46:56785Durchsuche

mongoDB数据库是一种以json格式存储的数据库,非常适用于各种应用开发,下面我来给各位朋友介绍一些mongoDB学习实例。


mongodb想要整合PHP,需要安装Mongo扩展,这个比较简单,现在说一下MongoDB PHPAPI  及用法
先看一个简单的例子:

Php代码 

1.

2.  $m = new Mongo();      //这里采用默认连接本机的27017端口,当然你也可以连接远程主机如                   192.168.0.4:27017,如果端口是27017,端口可以省略

3.   

4. $db = $m -> comedy;             // 选择comedy数据库,如果以前没该数据库会自动创建,也可以用$m->selectDB("comedy");  

5.   

6. $collection = $db->collection;  //选择comedy里面的collection集合,相当于RDBMS里面的表,也-可以使用  

7. $db->selectCollection("collection");  

8.   

9. $obj = array( "title" => "Calvin and Hobbes", "author" => "Bill Watterson" );  

10.   

11. $collection->insert($obj);     //将$obj 添加到$collection 集合中  

12.   

13.   

14. $obj = array( "title" => "XKCD", "online" => true );  

15. $collection->insert($obj);  

16. $cursor = $collection->find();  

17.   

18. foreach ($cursor as $obj) {    //遍历所有集合中的文档  

19. echo $obj["title"] . "n";  

20. }   

21.   

22.   

23. $m->close();          //断开MongoDB连接  

 

下面在介绍一些常用的函数:

Php代码 

1. $query = array( "i" => 71 );  

2. $cursor = $collection->find( $query );      // 在$collectio集合中查找满足$query的文档  

3.   

4. while( $cursor->hasNext() ) {  

5. var_dump( $cursor->getNext() );  

6. }   

7.   

8. $collection -> findOne();            //返回$collection集合中第一个文档  

9.   

10. $collection -> count();              //返回$collection集合中文档的数量  

11. $coll->ensureIndex( array( "i" => 1 ) );  // 为i “这一列”加索引 降序排列  

12. $coll->ensureIndex( array( "i" => -1, "j" => 1 ) );  // 为i “这一列”加索引 降序排列 j升序  

 

查询时,每个Object插入时都会自动生成一个独特的_id,它相当于RDBMS中的主键,用于查询时非常方便
如:

Php代码 

1.

2.   

3. $person = array("name" => "joe");  

4.   

5. $people->insert($person);  

6.   

7.  $joe = $people->findOne(array("_id" => $person['_id']));  

8.   

9. ?>  


更新时:

假如我们想修改下面文档中comments中author的名字

Php代码 

1. {   

2.     "_id" : ObjectId("4b06c282edb87a281e09dad9"),   

3.     "content" : "this is a blog post.",  

4.     "comments" :   

5.     [  

6.         {  

7.             "author" : "Mike",  

8.             "comment" : "I think that blah blah blah...",  

9.         },  

10.         {  

11.             "author" : "John",  

12.             "comment" : "I disagree."  

13.         }  

14.     ]  

15. }  

 

为了改变内部的一个域, 我们用 $set (保证文档中其他域不被移除)并且comment的索引也变化

Php代码 

1.

2.   

3. $collection->update($criteria, array('$set' => array("comments.1" => array("author" => "Jim")))); //$criteria 为要更新的元素  

4.   

5. ?>  


删除一个数据库

Php代码 

1. $m -> dropDB("comedy");  

 

列出所有可用数据库

Php代码 

1. $m->listDBs();   //无返回值 
好了就先 写这么多了,有兴趣的话可以在网上搜到其他的关于Mongo-php API的用法!

 

 

 

 

 

命令行使用实例:

1. db.system.users.find()  

2. db.users.count()  

3. db.users.ensureIndex({password:-1})  

4. use test  

5. db.users.getIndexes()  

6. db.repairDatabase()   

7. show users  

8. show dbs  

9. db.users.find({username:{$in:['4d81a82398790']}}).explain()  

10. db.users.dropIndexes()   

11. db.users.find().count()  

12. db.users.find().limit(5)  

13. db.users.find({"username":"ssa"})    

14. show collections   

15. db.users.remove()  

16. db.user.remove({'username':'admin'})  

17. db.user.insert({'username':'admin','age':21,'nickname':'admin'})  

18. db.user.save({'username':'admin','age':21,'info':['12','12313','zzsd']})  

19. db.createCollection("user")    

20. db.dropDatabase()   

21. show collections   

22. db.test.drop()   

23. db.copyDatabase('test','test1')  

24. show profile  

25. db.printCollectionStats()  

26. db.addUser('admin','admin123')    

27. db.setProfilingLevel(2);  

28. db.setProfilingLevel( 1 , 10 );  

29. db.system.profile.find() 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/632915.htmlTechArticlemongoDB数据库是一种以json格式存储的数据库,非常适用于各种应用开发,下面我来给各位朋友介绍一些mongoDB学习实例。 mongodb想要整合PHP,需...
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn