穹风嘞 發表於 2023-6-8 00:00:00

还有和Redis一样好用的NoSQL

<p>
        <img title="还有和Redis一样好用的NoSQL" alt="还有和Redis一样好用的NoSQL" border="0" height="auto" src="https://zhuji.jb51.net/uploads/img/202305/4863708332c527544cf3132794981ba7.jpg" width="auto"></p>
<p>
        实际上为了更好的描述实体之间的关系,我们要是再继续使用Redis的话,是不是感觉实体之间的关系不够那么的明显,虽然也是属于NoSQL的一种,但是相对来说,Redis,表现实体之间的关系就没有那么清晰了,为了更好的描述实体之间的关系,就会使用图形数据库来进行了,那么今天阿粉介绍的,就是一个图形化的数据可,Neo4J。</p>
<h3>
        什么是Neo4J</h3>
<p>
        Neo4j是一个世界领先的开源的基于图的数据库。它是使用Java语言完全开发的。那么什么是图数据库呢?图数据库是以图结构的形式存储数据的数据库。它以节点,关系和属性的形式存储应用程序的数据。正如RDBMS以表的“行,列”的形式存储数据,GDBMS以图的形式存储数据。</p>
<p>
        RDBMS与图数据库的区别</p>
<p>
        1.Tables 表Graphs 图表</p>
<p>
        2.Rows 行Nodes 节点</p>
<p>
        3.Columns and Data 列和数据 Properties and its values属性及其值</p>
<p>
        4.Constraints 约束Relationships 关系</p>
<p>
        5.Joins 加入Traversal 遍历</p>
<p>
        说完了图形数据库,我们就来看看这个 Neo4J 数据库吧</p>
<h3>
        Neo4J 数据库的安装</h3>
<p>
        neo4j是用Java语言编写的图形数据库,运行时需要启动JVM进程,因此,需安装JAVA SE的JDK。关于 Java 怎么安装,我就不用再多废话了吧,到时候别忘了检测一下 Java 的版本就好了,java -version</p>
<p>
        接下来我们就是要进行一个安装了,我们先去官网,下载社区版,企业版要收费的,注意哈。</p>
<p>
        官网地址</p>
<p>
        下载完成,直接开始安装,傻瓜式操作即可。</p>
<p>
        Neo4j应用程序有如下主要的目录结构:</p>
<ul>
<li>
                bin目录:用于存储Neo4j的可执行程序</li>
        <li>
                conf目录:用于控制Neo4j启动的配置文件</li>
        <li>
                data目录:用于存储核心数据库文件</li>
        <li>
                plugins目录:用于存储Neo4j的插件</li>
</ul>
<p>
        注意,如果你使用的是Zip的压缩包来进行的使用的话,那么你就需要注意一些地方,比如你如果是用 Zip 的包解压之后,并且想要通过 bat 的命令启动,直接在目录下进行 cmd ,然后 neo4j.bat ,这时候可能会出现一个问题,就是版本可能会出现问题,你如果下载使用的是最新版的 Neo4J ,那么就可能会让你使用 JDK 11 ,而阿粉就是踩过了这个大坑之后,才发现,bat 闪退的原因。</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>警告: ERROR! Neo4j cannot be started using java version 1.8.0_181 </span></span>
</li>
        <li>
                <span>警告: * Please use Oracle(R) Java(TM) 11, OpenJDK(TM) 11 <span class="keyword">to</span><span> run Neo4j Server. </span></span>
</li>
        <li class="alt">
                <span>* Please see https://neo4j.com/docs/ <span class="keyword">for</span><span> Neo4j installation instructions. </span></span>
</li>
        <li>
                <span>Invoke-Neo4j : This instance <span class="keyword">of</span><span> Java </span><span class="keyword">is</span><span> </span><span class="op">not</span><span> supported </span></span>
</li>
        <li class="alt">
                <span>所在位置 E:\softFile\neo4j-community-4.4.2\bin\neo4j.ps1:21 字符: 7 </span>
</li>
        <li>
                <span>+ Exit (Invoke-Neo4j -Verbose:$Arguments.Verbose -CommandArgs $Argument ... </span>
</li>
        <li class="alt">
                <span>+       ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ </span>
</li>
        <li>
                <span>    + CategoryInfo          : NotSpecified: (:) , WriteErrorException </span>
</li>
        <li class="alt">
                <span>    + FullyQualifiedErrorId : Microsoft.PowerShell.Commands.WriteErrorException,Invoke-Neo4j </span>
</li>
</ol>
<p>
        这样就是说明我们的 JDk 的版本对应的和 Neo4J 需要的 JDK 是不匹配的,我们就需要换一下我们的 JDK 了。把他换成 JDK 11 就好了,再次启动。</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>neo4j.bat console </span></span>
</li>
</ol>
<ol class="dp-sql">
<li class="alt">
                <span><span>E:\softFile\neo4j-community-4.4.2\bin&gt;neo4j.bat console </span></span>
</li>
        <li>
                <span>Directories <span class="op">in</span><span> use: </span></span>
</li>
        <li class="alt">
                <span>home:         E:\softFile\neo4j-community-4.4.2 </span>
</li>
        <li>
                <span>config:       E:\softFile\neo4j-community-4.4.2\conf </span>
</li>
        <li class="alt">
                <span>logs:         E:\softFile\neo4j-community-4.4.2\logs </span>
</li>
        <li>
                <span>plugins:      E:\softFile\neo4j-community-4.4.2\plugins </span>
</li>
        <li class="alt">
                <span>import:       E:\softFile\neo4j-community-4.4.2\import </span>
</li>
        <li>
                <span>data:         E:\softFile\neo4j-community-4.4.2\data </span>
</li>
        <li class="alt">
                <span>certificates: E:\softFile\neo4j-community-4.4.2\certificates </span>
</li>
        <li>
                <span>licenses:     E:\softFile\neo4j-community-4.4.2\licenses </span>
</li>
        <li class="alt">
                <span>run:          E:\softFile\neo4j-community-4.4.2\run </span>
</li>
        <li>
                <span>Starting Neo4j. </span>
</li>
        <li class="alt">
                <span>2021-12-19 12:37:08.121+0000 INFO  Starting... </span>
</li>
        <li>
                <span>2021-12-19 12:37:09.665+0000 INFO  This instance <span class="keyword">is</span><span> ServerId{25e1fcb1} (25e1fcb1-702c-4b58-bcdc-3564df95b2a1) </span></span>
</li>
        <li class="alt">
                <span>2021-12-19 12:37:11.957+0000 INFO  ======== Neo4j 4.4.2 ======== </span>
</li>
        <li>
                <span>2021-12-19 12:37:14.556+0000 INFO  Initializing system graph model <span class="keyword">for</span><span> component </span><span class="string">'security-users'</span><span> </span><span class="keyword">with</span><span> version -1 </span><span class="op">and</span><span> status UNINITIALIZED </span></span>
</li>
        <li class="alt">
                <span>2021-12-19 12:37:14.567+0000 INFO  Setting up initial <span class="func">user</span><span> </span><span class="keyword">from</span><span> defaults: neo4j </span></span>
</li>
        <li>
                <span>2021-12-19 12:37:14.568+0000 INFO  Creating new <span class="func">user</span><span> </span><span class="string">'neo4j'</span><span> (passwordChangeRequired=</span><span class="keyword">true</span><span>, suspended=</span><span class="keyword">false</span><span>) </span></span>
</li>
        <li class="alt">
                <span>2021-12-19 12:37:14.589+0000 INFO  Setting version <span class="keyword">for</span><span> </span><span class="string">'security-users'</span><span> </span><span class="keyword">to</span><span> 3 </span></span>
</li>
        <li>
                <span>2021-12-19 12:37:14.594+0000 INFO  <span class="keyword">After</span><span> initialization </span><span class="keyword">of</span><span> system graph model component </span><span class="string">'security-users'</span><span> have version 3 </span><span class="op">and</span><span> status </span><span class="keyword">CURRENT</span><span> </span></span>
</li>
        <li class="alt">
                <span>2021-12-19 12:37:14.601+0000 INFO  Performing postInitialization step <span class="keyword">for</span><span> component </span><span class="string">'security-users'</span><span> </span><span class="keyword">with</span><span> version 3 </span><span class="op">and</span><span> status </span><span class="keyword">CURRENT</span><span> </span></span>
</li>
        <li>
                <span>2021-12-19 12:37:15.979+0000 INFO  Bolt enabled <span class="keyword">on</span><span> 127.0.0.1:7687. </span></span>
</li>
        <li class="alt">
                <span>2021-12-19 12:37:17.200+0000 INFO  Remote interface available <span class="keyword">at</span><span> http://localhost:7474/ </span></span>
</li>
        <li>
                <span>2021-12-19 12:37:17.206+0000 INFO  id: 1ED17593750B5E6E3046A68E5254B92B64EE0B6CECA021D540D1B93BDFE67164 </span>
</li>
        <li class="alt">
                <span>2021-12-19 12:37:17.206+0000 INFO  <span class="keyword">name</span><span>: system </span></span>
</li>
        <li>
                <span>2021-12-19 12:37:17.207+0000 INFO  creationDate: 2021-12-19T12:37:12.956Z </span>
</li>
        <li class="alt">
                <span>2021-12-19 12:37:17.207+0000 INFO  Started. </span>
</li>
</ol>
<p>
        这时候,我们就直接访问 localhost:7474 的端口,直接就能看到如下的画面, 1.jpg</p>
<p>
        刚进入的时候可能需要大家输入帐号密码,默认的帐号密码就是,neo4j 修改成你想要的就行了。</p>
<p>
        这样登录进去我们就能开始正式学习 Neo4J 的所有内容了。</p>
<h3>
        Neo4J 的语法教学</h3>
<p>
        Neo4j - CQL语法</p>
<ul>
<li>
                它是Neo4j图形数据库的查询语言。</li>
        <li>
                它是一种声明性模式匹配语言</li>
        <li>
                它遵循SQL语法。</li>
        <li>
                它的语法是非常简单且人性化、可读的格式。</li>
</ul>
<p>
        我们在讲语法之前首先我们先得看看 Neo4J 的构建模块,不然之后的查询都是无意义的。</p>
<p>
        Neo4j图数据库主要有以下构建块 -</p>
<ul>
<li>
                节点</li>
        <li>
                属性</li>
        <li>
                关系</li>
        <li>
                标签</li>
        <li>
                数据浏览器</li>
</ul>
<p>
        节点是图表的基本单位。它包含具有键值对的属性,如下所示</p>
<p>
        属性是用于描述图节点和关系的键值对</p>
<p>
        关系是图形数据库的另一个主要构建块。它连接两个节点,如下所示。</p>
<p>
        Label将一个公共名称与一组节点或关系相关联。节点或关系可以包含一个或多个标签。我们可以为现有节点或关系创建新标签。我们可以从现有节点或关系中删除现有标签。</p>
<p>
        Neo4j数据浏览器 一旦我们安装Neo4j,我们可以访问Neo4j数据浏览器使用以下URL</p>
<p>
        http:// localhost:7474 / browser /</p>
<h3>
        CQL 语法</h3>
<p>
        <strong>CREATE 语法</strong></p>
<ol class="dp-sql">
<li class="alt">
                <span><span class="keyword">CREATE</span><span> (&lt;node-</span><span class="keyword">name</span><span>&gt;:&lt;label-</span><span class="keyword">name</span><span>&gt;) </span></span>
</li>
</ol>
<p>
        它是我们要创建的节点名称。</p>
<p>
        它是一个节点标签名称</p>
<p>
        我们可以创建一个节点,然后给他安排上一个标签</p>
<ol class="dp-sql">
<li class="alt">
                <span><span class="keyword">CREATE</span><span> (emp:Employee) </span></span>
</li>
</ol>
<p>
        当我们看到</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>Added 1 label, created 1 node, completed </span><span class="keyword">after</span><span> 74 ms. </span></span>
</li>
</ol>
<p>
        这就创建成功了,</p>
<p>
        那么怎么查看呢?</p>
<h3>
        MATCH语法</h3>
<ol class="dp-sql">
<li class="alt">
                <span><span>MATCH (&lt;node-</span><span class="keyword">name</span><span>&gt;:&lt;label-</span><span class="keyword">name</span><span>&gt;) </span><span class="keyword">return</span><span> xxx </span></span>
</li>
</ol>
<p>
        是这个样子的</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>MATCH (emp:Employee) </span><span class="keyword">return</span><span> emp </span></span>
</li>
</ol>
<ol class="dp-sql">
<li class="alt">
                <span><span>╒═════╕ </span></span>
</li>
        <li>
                <span>│<span class="string">"emp"</span><span>│ </span></span>
</li>
        <li class="alt">
                <span>╞═════╡ </span>
</li>
        <li>
                <span>│{}   │ </span>
</li>
        <li class="alt">
                <span>└─────┘ </span>
</li>
</ol>
<p>
        但是看到里面竟然没有东西,就相当于是一个空的对象,那是不是就应该给里面放入属性的操作呢?没错,肯定有</p>
<p>
        CREATE (emp:Employee{ id : 1001 ,name :"lucy", age : 10})</p>
<p>
        Added 1 label, created 1 node, set 3 properties, completed after 163 ms. 创建成功。</p>
<p>
        我们再次查看就能看到</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>╒══════════════════════════════════╕ </span></span>
</li>
        <li>
                <span>│<span class="string">"emp"</span><span>                             │ </span></span>
</li>
        <li class="alt">
                <span>╞══════════════════════════════════╡ </span>
</li>
        <li>
                <span>│{}                                │ </span>
</li>
        <li class="alt">
                <span>├──────────────────────────────────┤ </span>
</li>
        <li>
                <span>│{<span class="string">"name"</span><span>:</span><span class="string">"lucy"</span><span>,</span><span class="string">"id"</span><span>:1001,</span><span class="string">"age"</span><span>:10}│ </span></span>
</li>
        <li class="alt">
                <span>└──────────────────────────────────┘ </span>
</li>
</ol>
<p>
        如果我们想只要其中的一些对象的属性,而不是全部属性,那应该怎么操作呢?</p>
<h3>
        RETURN语法</h3>
<p>
        RETURN 可以返回的是一个对象,也可以是对象中的属性,比如:</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>MATCH (emp:Employee) </span><span class="keyword">return</span><span> emp.</span><span class="keyword">name</span><span> </span></span>
</li>
</ol>
<p>
        结果就是下面这个样子的,大家看一下,是不是感觉还是挺好用的。</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>╒══════════╕ </span></span>
</li>
        <li>
                <span>│<span class="string">"emp.name"</span><span>│ </span></span>
</li>
        <li class="alt">
                <span>╞══════════╡ </span>
</li>
        <li>
                <span>│<span class="string">"Lokesh"</span><span>  │ </span></span>
</li>
        <li class="alt">
                <span>├──────────┤ </span>
</li>
        <li>
                <span>│<span class="string">"jack"</span><span>    │ </span></span>
</li>
        <li class="alt">
                <span>├──────────┤ </span>
</li>
        <li>
                <span>│<span class="string">"luxun"</span><span>   │ </span></span>
</li>
        <li class="alt">
                <span>├──────────┤ </span>
</li>
        <li>
                <span>│<span class="string">"lucy"</span><span>    │ </span></span>
</li>
        <li class="alt">
                <span>└──────────┘ </span>
</li>
</ol>
<p>
        <strong>** WHERE语法**</strong></p>
<ol class="dp-sql">
<li class="alt">
                <span><span class="keyword">WHERE</span><span> &lt;condition&gt; </span></span>
</li>
</ol>
<p>
        为什么在前面的位置阿粉说,CQL 是和 SQL 类型的,这完全是因为很多东西和 SQL 是类似的。</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>MATCH (emp:Employee) </span><span class="keyword">where</span><span> emp.</span><span class="keyword">name</span><span> = </span><span class="string">'jack'</span><span> </span><span class="keyword">return</span><span> emp </span></span>
</li>
</ol>
<p>
        结果如下:</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>╒════════════════════════════════════════════════╕ </span></span>
</li>
        <li>
                <span>│<span class="string">"emp"</span><span>                                           │ </span></span>
</li>
        <li class="alt">
                <span>╞════════════════════════════════════════════════╡ </span>
</li>
        <li>
                <span>│{<span class="string">"name"</span><span>:</span><span class="string">"jack"</span><span>,</span><span class="string">"id"</span><span>:125,</span><span class="string">"deptno"</span><span>:10,</span><span class="string">"sal"</span><span>:35800}│ </span></span>
</li>
        <li class="alt">
                <span>└────────────────────────────────────────────────┘ </span>
</li>
</ol>
<p>
        相同的还有</p>
<table style='margin: 0px 0px 10px; padding: 0px; outline: 0px; border-collapse: collapse; width: 525px; max-width: 100%; color: rgb(63, 63, 63); font-family: Optima-Regular, Optima, PingFangSC-light, PingFangTC-light, "PingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif; font-size: 16px; letter-spacing: 0.544px; box-sizing: border-box !important; overflow-wrap: break-word !important;'>
<thead><tr>
<th>
                                布尔运算符</th>
                        <th>
                                描述</th>
                </tr></thead>
<tbody>
<tr>
<td>
                                AND</td>
                        <td>
                                和</td>
                </tr>
<tr>
<td>
                                OR</td>
                        <td>
                                或者</td>
                </tr>
<tr>
<td>
                                NOT</td>
                        <td>
                                非</td>
                </tr>
<tr>
<td>
                                XOR</td>
                        <td>
                                异或</td>
                </tr>
</tbody>
</table>
<table style='margin: 0px 0px 10px; padding: 0px; outline: 0px; border-collapse: collapse; width: 525px; max-width: 100%; color: rgb(63, 63, 63); font-family: Optima-Regular, Optima, PingFangSC-light, PingFangTC-light, "PingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif; font-size: 16px; letter-spacing: 0.544px; box-sizing: border-box !important; overflow-wrap: break-word !important;'>
<thead><tr>
<th>
                                比较运算符</th>
                        <th>
                                描述</th>
                </tr></thead>
<tbody>
<tr>
<td>
                                =</td>
                        <td>
                                “等于”运算符</td>
                </tr>
<tr>
<td>
                                &lt;&gt;</td>
                        <td>
                                “不等于”运算符</td>
                </tr>
<tr>
<td>
                                &lt;</td>
                        <td>
                                “小于”运算符</td>
                </tr>
<tr>
<td>
                                &gt;</td>
                        <td>
                                “大于”运算符</td>
                </tr>
<tr>
<td>
                                &lt;=</td>
                        <td>
                                “小于或等于”运算符。</td>
                </tr>
<tr>
<td>
                                &gt;=</td>
                        <td>
                                “大于或等于”运算符。</td>
                </tr>
</tbody>
</table>
<h3>
        DELETE语法</h3>
<p>
        删除语法必然是有的,因为有创建,肯定有删除。</p>
<ol class="dp-sql">
<li class="alt">
                <span><span class="keyword">DELETE</span><span> &lt;node-</span><span class="keyword">name</span><span>-list&gt; </span></span>
</li>
</ol>
<p>
        但是这个命令也不是单独使用的哈,</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>MATCH (e: Employee) </span><span class="keyword">DELETE</span><span> e </span></span>
</li>
</ol>
<p>
        直接删除成功。</p>
<p>
        基础的东西讲完了,阿粉就得说说这个比较重要的内容了,关系,</p>
<h3>
        Neo4j 的关系</h3>
<p>
        我们之前创建节点的时候,那叫一个简单舒适加愉快,但是创建关系就比较复杂了,因为需要考虑如何匹配到有关系的两个节点,以及关系本身的属性如何设置。这里我们就简单学一下如何建立节点之间的关系。</p>
<p>
        由于Neo4j CQL语法是以人类可读的格式。Neo4j CQL也使用类似的箭头标记来创建两个节点之间的关系。</p>
<p>
        每个关系(→)包含两个节点</p>
<p>
        在Neo4j中,两个节点之间的关系是有方向性的。它们是单向或双向的。</p>
<p>
        如果我们尝试创建一个没有任何方向的关系,那么就会报错。</p>
<h3>
        关系创建语法</h3>
<ol class="dp-sql">
<li class="alt">
                <span><span class="keyword">CREATE</span><span> (&lt;node1-details&gt;)-[&lt;relationship-details&gt;]-&gt;(&lt;node2-details&gt;) </span></span>
</li>
</ol>
<p>
        我们这里直接使用创建新的节点来创建关系。</p>
<ol class="dp-sql">
<li class="alt">
                <span><span class="keyword">CREATE</span><span> (book:Book)-[</span><span class="keyword">contains</span><span>:</span><span class="keyword">CONTAINS</span><span>]-&gt;(bookStore:BOOKSTORE) </span></span>
</li>
</ol>
<p>
        提示创建成功</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>Added 2 labels, created 2 nodes, created 1 relationship, completed </span><span class="keyword">after</span><span> 199 ms. </span></span>
</li>
</ol>
<p>
        这里关系名称是“CONTAINS”</p>
<p>
        关系标签是“contains”。</p>
<ol class="dp-sql">
<li class="alt">
                <span><span>MATCH (book:Book)-[</span><span class="keyword">contains</span><span>:</span><span class="keyword">CONTAINS</span><span>]-&gt;(bookStore:BOOKSTORE) </span><span class="keyword">return</span><span> </span><span class="keyword">contains</span><span> </span></span>
</li>
</ol>
<p>
        这么看是看不出有啥关系的,但是,我们可以从另外的一个位置</p>
<p>
        <img title="还有和Redis一样好用的NoSQL" alt="还有和Redis一样好用的NoSQL" border="0" height="auto" src="https://zhuji.jb51.net/uploads/img/202305/86d4d82240009a6f33d7c598a9c2a683.jpg" width="auto"></p>
<p>
        这样看下来,这个 Neo4J 简单操作是不是就学会了,阿粉接下来的文章中讲怎么使用 Java 来操作 Neo4J 数据库。欢迎大家来观看。</p>
<p>
        原文链接:https://mp.weixin.qq.com/s/VX3ERRZykfHg1GbIwqYEOg</p>
頁: [1]
查看完整版本: 还有和Redis一样好用的NoSQL