PRF&PUB:20170713 Fundamentals of graph databases with Neo4j.md

@geekpi
This commit is contained in:
wxy 2017-07-27 15:15:10 +08:00
parent 6547a6b000
commit 1915cf3339
2 changed files with 68 additions and 84 deletions

View File

@ -0,0 +1,68 @@
Neo4j 图数据库基础
============================================================
> 在这个三篇系列文章的第一篇文章中我们将学习图数据库graph database的基础知识它支持了这地球上最大的一些数据池。
![Fundamentals of graph databases with Neo4j](https://opensource.com/sites/default/files/styles/image-full-size/public/images/life/grasshopper_graph_lead.jpg?itok=X5QPAGYh "Fundamentals of graph databases with Neo4j")
对于海量的各种非结构化信息来说,图数据库已经成为帮助收集、管理和搜索大量数据的技术。在这三篇系列文章中,我们将使用开源图数据库软件 [Neo4j][9] 来研究图数据库。
在本文中,我将向你展示图数据库的基础知识,帮助你快速了解概念模型。在第二篇中,我将向你展示如何启动 Neo4j 数据库,并使用内置的浏览器工具填充一些数据。而且,在本系列的最后一篇文章中,我们将探讨一些在开发工作中使用的 Neo4j 编程库。
掌握图数据库的概念模型是有用的,所以我们从那里开始。图数据库中只存储两种数据:<ruby>节点<rt>node</rt></ruby><ruby><rt>edge</rt></ruby>
* **节点是实体:**诸如人物、发票、电影、书籍或其他具体事物。这些有些等同于关系数据库中的记录或行。
* **边名关系:**连接节点的概念、事件或事物。在关系数据库中,这些关系通常存储在具有链接字段的数据库行中。在图数据库中,它们本身就是有用的,是可以以其自己的权限搜索的对象。
节点和边都可以拥有可搜索的_属性_。例如如果你的节点代表人他们可能拥有名字、性别、出生日期、身高等属性。而边的属性可能描述了两个人之间的关系何时建立见面的情况或关系的性质。
这是一个帮助你可视化的图表:
![Graph database image 1](https://opensource.com/sites/default/files/u128651/article_1_image_1.jpg "Graph database image 1")
在这张图中,你知道 Jane Doe 有一个新的丈夫 John一个女儿来自她以前的夫妻关系Mary Smith 和朋友 Robert 和 Rhonda Roe。Roes 有一个儿子 Ryan他正在与 Mary Smith 约会。
看看它怎么工作每个节点代表一个独立于其他节点的人。你需要找到关于_那个_人的一切都可以存储在节点的属性中。边描述了人们之间的关系这与你在程序中需要的一样多。
关系是单向的,且不能是无向的,但这没有问题。由于数据库可以以相同的速度遍历两个方向,并且方向可以忽略,你只需要定义一次此关系。如果你的程序需要定向关系,则可以自由使用它们,但如果双向性是暗含的,则不需要。
另外需要注意的是,图数据库本质上是无 schema 的。这与关系数据库不同,关系数据库每行都有一组列表,并且添加新的字段会给开发和升级带来很多工作。
每个节点都可以拥有一个<ruby>标签<rt>label</rt></ruby>;对于大多数程序你需要“输入”这个标签,是对典型的关系数据库中的表名的模拟。标签可以让你区分不同的节点类型。如果你需要添加新的标签或属性,修改程序来用它就行!
使用图数据库,你可以直接开始使用新的属性和标签,节点将在创建或编辑时获取它们。不需要转换东西;只需在你的代码中使用它们即可。在这里的例子中,你可以看到,我们知道 Jane 和 Mary 最喜欢的颜色和 Mary 的出生日期,但是别人没有(这些属性)。这个系统不需要知道它;用户可以在正常使用程序的过程中访问节点时为其添加信息(属性)。
作为一名开发人员,这是一个有用的特性。你可以将新的标签或属性添加到由节点处理的表单中并开始使用它,而不必进行数据库 schema 的修改。对于没有该属性的节点,将不显示任何内容。你可以使用任何一种类型的数据库来为表单进行编码,但是你可以放下在关系型数据库中要进行的许多后端工作了。
让我们添加一些新的信息:
![Graph database image 2, defining a new type of node](https://opensource.com/sites/default/files/u128651/article_1_image_2.jpg "Graph database image 2, defining a new type of node")
这是一个新的节点类型,它代表一个位置,以及一些相关关系。现在我们看到 John Doe 出生在加利福尼亚州的 Petaluma而他的妻子 Jane 则出生在德克萨斯州的 Grand Prairie。 他们现在住在得克萨斯州的赛普拉斯,因为 Jane 在附近的休斯顿工作。Ryan Roe 缺乏城市关系对数据库来说没有什么大不了的事情我们_不知道_那些信息而已。当用户输入更多数据时数据库可以轻松获取新数据并添加新数据并根据需要创建新的节点和关系。
了解节点和边应该足以让你开始使用图形数据库。如果你像我一样,已经在考虑如何在一个图中重组你的程序。在本系列的下一篇文章中,我将向你展示如何安装 Neo4j、插入数据并进行一些基本的搜索。
(题图:由 Jen Wike Huger 修改CC BY-SA
--------------------------------------------------------------------------------
via: https://opensource.com/article/17/7/fundamentals-graph-databases-neo4j
作者:[Ruth Holloway][a]
译者:[geekpi](https://github.com/geekpi)
校对:[wxy](https://github.com/wxy)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]:https://opensource.com/users/druthb
[1]:https://opensource.com/tags/python?src=programming_resource_menu1
[2]:https://opensource.com/tags/javascript?src=programming_resource_menu2
[3]:https://opensource.com/tags/perl?src=programming_resource_menu3
[4]:https://developers.redhat.com/?intcmp=7016000000127cYAAQ&src=programming_resource_menu4
[5]:https://opensource.com/file/363056
[6]:https://opensource.com/file/363061
[7]:https://opensource.com/article/17/7/fundamentals-graph-databases-neo4j?rate=QlLa3Y_1alHoy77MX2w69IZN5nYBJZrkZ0b2F_0wH_A
[8]:https://opensource.com/user/36051/feed
[9]:https://neo4j.com/
[10]:https://opensource.com/users/druthb
[11]:https://opensource.com/users/druthb

View File

@ -1,84 +0,0 @@
Neo4j 图数据库的基础
============================================================
### 在共三部的第一部分中,我们将学习图形数据库的基础知识,它为这地球上最大的一些数据库提供支持。
![Fundamentals of graph databases with Neo4j](https://opensource.com/sites/default/files/styles/image-full-size/public/images/life/grasshopper_graph_lead.jpg?itok=X5QPAGYh "Fundamentals of graph databases with Neo4j")
图片来源: 
由 Jen Wike Huger 修改CC BY-SA
对于非常大量的各种非结构化信息,图数据库已经成为帮助收集、管理和搜索大量数据的技术。在这三部分系列中,我们将使用 [Neo4j][9],一个开源图数据库来研究图数据库。
在本文中,我将向你展示图数据库的基础知识,帮助你快速了解概念模型。第二,我将向你展示如何启动 Neo4j 数据库,并使用内置的浏览器工具填充一些数据。而且,在本系列的最后一篇文章中,我们将探讨一些在开发工作中使用 Neo4j 的编程库。
掌握图数据库的概念模型是有用的所以我们从那里开始。图数据库中只存储两种数据_节点_和_边_。
* **节点是实体:**诸如人物、发票、电影、书籍或其他具体事物。这些有些等同于关系数据库中的记录或行。
* **边名关系:**连接节点的概念、事件或事物。在关系数据库中,这些关系通常存储在具有链接字段的数据库行中。在图形数据库中,它们本身就是有用的,可搜索的对象。
节点和边都可以拥有可搜索的_属性_。例如如果你的节点代表人他们可能拥有名字、性别、出生日期、身高等属性。边属性可能描述了两个人之间的关系何时建立见面的情况或关系的性质。
这是一个帮助你可视化的图表:
### [article_1_image_1.jpg][5]
![Graph database image 1](https://opensource.com/sites/default/files/u128651/article_1_image_1.jpg "Graph database image 1")
在这张图中,你知道 Jane Doe 有一个新的丈夫 John;一个女儿从她以前的关系Mary Smith 和朋友 Robert 和 Rhonda Roe。Roes 有一个儿子 Ryan他正在与 Mary Smith 约会。
看看它怎么工作每个节点代表一个独立于其他节点的人。你需要找到关于_那个_ 人的一切都可以存储在节点的属性中。边描述了人们之间的关系,这与你在程序中需要的一样多。
关系是单向的,且不能无向,但这没有问题。由于数据库可以以相同的速度遍历两个方向,并且方向可以忽略,你只需要定义一次此关系。如果你的程序需要定向关系,则可以自由使用它们,但如果双向性是暗含的,则不需要。
编程与开发
* [新的 Python 内容][1]
* [我们最新的 JavaScript 文章][2]
* [最近的 Perl 帖子][3]
* [红帽开发者博客][4]
另外需要注意的是,图数据库本质上是无 schema 的。这与关系数据库不同,每行都有一组列表,并且添加新的字段是开发和升级的主要工作。
每个节点都可以拥有一个_标签_;这个标签是大多数程序你需要“输入”的,是典型关系数据库中表名的模拟。标签可以让你区分不同的节点类型。如果你需要添加新的标签或属性,请更改你的程序来开始使用!
使用图数据库,你可以直接开始使用新的属性和标签,节点将在创建或编辑时获取它们。没有必要去转换东西;只需开始在你的代码中使用它们。在这里的例子中,你可以看到,我们知道 Jane 和 Mary 最喜欢的颜色和 Mary 的出生日期,但是别人没有。这个系统不需要知道它;用户可以在程序使用中随意访问节点,添加任意信息。
作为一名开发人员,这是一个有用的特性。你可以将新的标签或属性添加到由节点处理的表单中并开始使用它,而不必进行数据库 schema 修改。对于没有属性的节点,将不显示任何内容。你需要使用任一类型的数据库对表单进行编码,但是你可以放下在关系型数据库中要进行的后端工作了。
让我们添加一些新的信息:
### [article_1_image_2.jpg][6]
![Graph database image 2, defining a new type of node](https://opensource.com/sites/default/files/u128651/article_1_image_2.jpg "Graph database image 2, defining a new type of node")
这是一个新的节点类型,它代表一个位置,以及一些相关关系。现在我们看到 John Doe 出生在加利福尼亚州的 Petaluma而他的妻子 Jane 则出生在德克萨斯州的 Grand Prairie。 他们现在住在得克萨斯州的赛普拉斯,因为 Jane 在附近的休斯顿工作。Ryan Roe 缺乏城市关系对数据库来说没有什么大不了的事情我们_不知道_那些信息。当用户输入更多数据时数据库可以轻松获取新数据并添加新数据根据需要创建新的节点和关系。
了解节点和边应该足以让你开始使用图形数据库。如果你像我一样,你已经在考虑如何在一个图中重组你的程序。在本系列的下一篇文章中,我将向你展示如何安装 Neo4j、插入数据并进行一些基本的搜索。
--------------------------------------------------------------------------------
via: https://opensource.com/article/17/7/fundamentals-graph-databases-neo4j
作者:[Ruth Holloway ][a]
译者:[geekpi](https://github.com/geekpi)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]:https://opensource.com/users/druthb
[1]:https://opensource.com/tags/python?src=programming_resource_menu1
[2]:https://opensource.com/tags/javascript?src=programming_resource_menu2
[3]:https://opensource.com/tags/perl?src=programming_resource_menu3
[4]:https://developers.redhat.com/?intcmp=7016000000127cYAAQ&src=programming_resource_menu4
[5]:https://opensource.com/file/363056
[6]:https://opensource.com/file/363061
[7]:https://opensource.com/article/17/7/fundamentals-graph-databases-neo4j?rate=QlLa3Y_1alHoy77MX2w69IZN5nYBJZrkZ0b2F_0wH_A
[8]:https://opensource.com/user/36051/feed
[9]:https://neo4j.com/
[10]:https://opensource.com/users/druthb
[11]:https://opensource.com/users/druthb