我爱编程程序员华南理工大学无线电爱好者协会软件小组

MongoDB-非关系型数据库

2016-09-30  本文已影响0人  honehou

NoSQL

NoSQL,指非关系型的数据库。NoSQL有时也称作Not Only SQL的缩写,是对不同于传统的关系型数据库(RDBMS)的数据库管理系统的统称。NoSQL用于超大规模数据的存储(例如谷歌或Facebook每天为他们的用户收集万亿比特的数据)。这些类型的数据存储不需要固定的模式,无需多余操作就可以横向扩展。NoSQL与关系型数据库存在许多显著的不同点,其中最重要的是NoSQL不使用SQL作为查询语言。其数据存储可以不需要固定的表格模式,也经常会避免使用SQL的JOIN操作,一般有水平可扩展性的特征。NoSQL的四大分类为:键值存储数据库、列存储数据库、文档型数据库(MongoDB属于该类)、图形数据库。

关于SQL与NoSQL详细区别可参考:NoSQL 简介 | 菜鸟教程

MongoDB

MongoDB是一款高性能、高可靠性,由C++语言编写的,基于分布式文件存储的开源数据库系统。MongoDB旨在为WEB应用提供可扩展的高性能数据存储解决方案。

推荐一个图形化管理工具Robomongo:
https://robomongo.org/download

官方文档中,MongoDB的基本概念如下:

Databases:
In MongoDB, databases hold collections of documents.
Collections:
MongoDB stores documents in collections. Collections are analogous to tables in relational databases.
Documents:
MongoDB stores data records as BSON documents. BSON is a binary representation of JSON documents, though it contains more data types than JSON.

MongoDB 将数据存储为一个文档,文档包含在集合中,而集合包含在数据库中。文档的数据结构由键值(key=>value)对组成(即BSON),类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。MongoDB与SQL基本概念的对比如下图:


MongoDB与SQL基本概念对比
文档
集合

MongoDB与PHP

$m = new MongoClient(); // connect
$db = $m->test; // get the database named "test",if not then create
$collection = $db->createCollection("collection");// create a collection named "collection"
$document = [ 
    "name" => "sue", 
    "age" => 26,
    "status" => "A",
    "group" => [
        "news" => "news",
        "sports" => "basketball"
    ]
];
$collection->insert($document);// insert document
在Robomongo中查看文档是否插入
$findOne = $collection->findOne(array("name" => "sue"));
var_dump($findOne);
查找文档结果
$newData = [
    '$set' =>[
        "age" => 18,
        "newData" => "newData"
    ]
];
$collection->update(array("name" => "sue"),$newData);
$findOne = $collection->findOne(array("name" => "sue"));
var_dump($findOne);

注意此处$newData,首先$set需要用单引号括起来(双引号会解析变量),其次实际更改的内容放在第二维数组里,否则操作会直接覆盖原数据。在格式正确的基础上,若新数据与原数据字段名相同的则修改,不同则添加。

更新文档
$collection->remove(array("name" => "sue"),array("justOne" => true));

对于array("justOne" => true),表示只删除一个文档,如果它为false则会删除全部符合删除条件的文档。

参考:MongoDB官方文档PHP官网MongoDB 教程 | 菜鸟教程

上一篇 下一篇

猜你喜欢

热点阅读