內(nèi)存數(shù)據(jù)庫(kù),也叫緩存,可以存儲(chǔ)訪問(wèn)頻次很高的數(shù)據(jù)
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶,將通過(guò)不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名注冊(cè)、網(wǎng)站空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、望都網(wǎng)站維護(hù)、網(wǎng)站推廣。
redis是一個(gè)nosql(not only sql不僅僅只有sql)數(shù)據(jù)庫(kù),翻譯成中文叫做非關(guān)系型型數(shù)據(jù)庫(kù)
首先需要Linux相關(guān)知識(shí),推薦Linux實(shí)戰(zhàn)教程:
解壓成功之后,便可以看到一個(gè)redis-6.2.5的文件夾,文件夾中有如下文件:
成功安裝如下
redis默認(rèn)安裝的路徑為 /usr/loacl/bin ,進(jìn)入文件夾則發(fā)現(xiàn)redis文件:
首先必須在 /usr/local/bin 這個(gè)目錄下,啟動(dòng)redis服務(wù)。啟動(dòng)服務(wù)的命令 redis-server northconfig/redis.conf
實(shí)際上為了更好的描述實(shí)體之間的關(guān)系,我們要是再繼續(xù)使用Redis的話,是不是感覺(jué)實(shí)體之間的關(guān)系不夠那么的明顯,雖然也是屬于NoSQL的一種,但是相對(duì)來(lái)說(shuō),Redis,表現(xiàn)實(shí)體之間的關(guān)系就沒(méi)有那么清晰了,為了更好的描述實(shí)體之間的關(guān)系,就會(huì)使用圖形數(shù)據(jù)庫(kù)來(lái)進(jìn)行了,那么今天阿粉介紹的,就是一個(gè)圖形化的數(shù)據(jù)可,Neo4J。
Neo4j是一個(gè)世界領(lǐng)先的開(kāi)源的基于圖的數(shù)據(jù)庫(kù)。 它是使用Java語(yǔ)言完全開(kāi)發(fā)的。那么什么是圖數(shù)據(jù)庫(kù)呢?圖數(shù)據(jù)庫(kù)是以圖結(jié)構(gòu)的形式存儲(chǔ)數(shù)據(jù)的數(shù)據(jù)庫(kù)。 它以節(jié)點(diǎn),關(guān)系和屬性的形式存儲(chǔ)應(yīng)用程序的數(shù)據(jù)。正如RDBMS以表的“行,列”的形式存儲(chǔ)數(shù)據(jù),GDBMS以圖的形式存儲(chǔ)數(shù)據(jù)。
RDBMS與圖數(shù)據(jù)庫(kù)的區(qū)別
1.Tables 表Graphs 圖表
2.Rows 行Nodes 節(jié)點(diǎn)
3.Columns and Data 列和數(shù)據(jù) Properties and its values屬性及其值
4.Constraints 約束Relationships 關(guān)系
5.Joins 加入Traversal 遍歷
說(shuō)完了圖形數(shù)據(jù)庫(kù),我們就來(lái)看看這個(gè) Neo4J 數(shù)據(jù)庫(kù)吧
neo4j是用Java語(yǔ)言編寫的圖形數(shù)據(jù)庫(kù),運(yùn)行時(shí)需要啟動(dòng)JVM進(jìn)程,因此,需安裝JAVA SE的JDK。關(guān)于 Java 怎么安裝,我就不用再多廢話了吧,到時(shí)候別忘了檢測(cè)一下 Java 的版本就好了, java -version
接下來(lái)我們就是要進(jìn)行一個(gè)安裝了,我們先去官網(wǎng),下載社區(qū)版,企業(yè)版要收費(fèi)的,注意哈。
官網(wǎng)地址
下載完成,直接開(kāi)始安裝,傻瓜式操作即可。
Neo4j應(yīng)用程序有如下主要的目錄結(jié)構(gòu):
注意,如果你使用的是Zip的壓縮包來(lái)進(jìn)行的使用的話,那么你就需要注意一些地方,比如你如果是用 Zip 的包解壓之后,并且想要通過(guò) bat 的命令啟動(dòng),直接在目錄下進(jìn)行 cmd ,然后 neo4j.bat ,這時(shí)候可能會(huì)出現(xiàn)一個(gè)問(wèn)題,就是版本可能會(huì)出現(xiàn)問(wèn)題,你如果下載使用的是最新版的 Neo4J ,那么就可能會(huì)讓你使用 JDK 11 ,而阿粉就是踩過(guò)了這個(gè)大坑之后,才發(fā)現(xiàn),bat 閃退的原因。
這樣就是說(shuō)明我們的 JDk 的版本對(duì)應(yīng)的和 Neo4J 需要的 JDK 是不匹配的,我們就需要換一下我們的 JDK 了。把他換成 JDK 11 就好了,再次啟動(dòng)。
這時(shí)候,我們就直接訪問(wèn) localhost:7474 的端口,直接就能看到如下的畫(huà)面, 1.jpg
剛進(jìn)入的時(shí)候可能需要大家輸入帳號(hào)密碼,默認(rèn)的帳號(hào)密碼就是,neo4j 修改成你想要的就行了。
這樣登錄進(jìn)去我們就能開(kāi)始正式學(xué)習(xí) Neo4J 的所有內(nèi)容了。
Neo4j - CQL語(yǔ)法
我們?cè)谥v語(yǔ)法之前首先我們先得看看 Neo4J 的構(gòu)建模塊,不然之后的查詢都是無(wú)意義的。
Neo4j圖數(shù)據(jù)庫(kù)主要有以下構(gòu)建塊 -
節(jié)點(diǎn)是圖表的基本單位。 它包含具有鍵值對(duì)的屬性,如下所示
屬性是用于描述圖節(jié)點(diǎn)和關(guān)系的鍵值對(duì)
關(guān)系是圖形數(shù)據(jù)庫(kù)的另一個(gè)主要構(gòu)建塊。 它連接兩個(gè)節(jié)點(diǎn),如下所示。
Label將一個(gè)公共名稱與一組節(jié)點(diǎn)或關(guān)系相關(guān)聯(lián)。 節(jié)點(diǎn)或關(guān)系可以包含一個(gè)或多個(gè)標(biāo)簽。 我們可以為現(xiàn)有節(jié)點(diǎn)或關(guān)系創(chuàng)建新標(biāo)簽。 我們可以從現(xiàn)有節(jié)點(diǎn)或關(guān)系中刪除現(xiàn)有標(biāo)簽。
Neo4j數(shù)據(jù)瀏覽器 一旦我們安裝Neo4j,我們可以訪問(wèn)Neo4j數(shù)據(jù)瀏覽器使用以下URL
http:// localhost:7474 / browser /
CREATE 語(yǔ)法
CREATE ( : )
它是我們要?jiǎng)?chuàng)建的節(jié)點(diǎn)名稱。
它是一個(gè)節(jié)點(diǎn)標(biāo)簽名稱
我們可以創(chuàng)建一個(gè)節(jié)點(diǎn),然后給他安排上一個(gè)標(biāo)簽
CREATE (emp:Employee)
當(dāng)我們看到
Added 1 label, created 1 node, completed after 74 ms.
這就創(chuàng)建成功了,
那么怎么查看呢?
MATCH語(yǔ)法
MATCH ( : ) return xxx
是這個(gè)樣子的
但是看到里面竟然沒(méi)有東西,就相當(dāng)于是一個(gè)空的對(duì)象,那是不是就應(yīng)該給里面放入屬性的操作呢?沒(méi)錯(cuò),肯定有
CREATE (emp:Employee{ id : 1001 ,name :"lucy", age : 10})
Added 1 label, created 1 node, set 3 properties, completed after 163 ms. 創(chuàng)建成功。
我們?cè)俅尾榭淳湍芸吹?/p>
如果我們想只要其中的一些對(duì)象的屬性,而不是全部屬性,那應(yīng)該怎么操作呢?
RETURN語(yǔ)法
RETURN 可以返回的是一個(gè)對(duì)象,也可以是對(duì)象中的屬性,比如:
結(jié)果就是下面這個(gè)樣子的,大家看一下,是不是感覺(jué)還是挺好用的。
** WHERE語(yǔ)法**
WHERE
為什么在前面的位置阿粉說(shuō),CQL 是和 SQL 類型的,這完全是因?yàn)楹芏鄸|西和 SQL 是類似的。
結(jié)果如下:
相同的還有
布爾運(yùn)算符 描述 AND 和 OR 或者 NOT 非 XOR 異或
比較運(yùn)算符 描述 = “等于”運(yùn)算符 “不等于”運(yùn)算符 “小于”運(yùn)算符 “大于”運(yùn)算符 = “小于或等于”運(yùn)算符。 = “大于或等于”運(yùn)算符。
DELETE語(yǔ)法
刪除語(yǔ)法必然是有的,因?yàn)橛袆?chuàng)建,肯定有刪除。
DELETE
但是這個(gè)命令也不是單獨(dú)使用的哈,
MATCH (e: Employee) DELETE e
直接刪除成功。
基礎(chǔ)的東西講完了,阿粉就得說(shuō)說(shuō)這個(gè)比較重要的內(nèi)容了,關(guān)系,
我們之前創(chuàng)建節(jié)點(diǎn)的時(shí)候,那叫一個(gè)簡(jiǎn)單舒適加愉快,但是創(chuàng)建關(guān)系就比較復(fù)雜了,因?yàn)樾枰紤]如何匹配到有關(guān)系的兩個(gè)節(jié)點(diǎn),以及關(guān)系本身的屬性如何設(shè)置。這里我們就簡(jiǎn)單學(xué)一下如何建立節(jié)點(diǎn)之間的關(guān)系。
由于Neo4j CQL語(yǔ)法是以人類可讀的格式。 Neo4j CQL也使用類似的箭頭標(biāo)記來(lái)創(chuàng)建兩個(gè)節(jié)點(diǎn)之間的關(guān)系。
每個(gè)關(guān)系( )包含兩個(gè)節(jié)點(diǎn)
在Neo4j中,兩個(gè)節(jié)點(diǎn)之間的關(guān)系是有方向性的。 它們是單向或雙向的。
如果我們嘗試創(chuàng)建一個(gè)沒(méi)有任何方向的關(guān)系,那么就會(huì)報(bào)錯(cuò)。
關(guān)系創(chuàng)建語(yǔ)法
CREATE ( )-[ ]-( )
我們這里直接使用創(chuàng)建新的節(jié)點(diǎn)來(lái)創(chuàng)建關(guān)系。
提示創(chuàng)建成功
這里關(guān)系名稱是“CONTAINS”
關(guān)系標(biāo)簽是“contains”。
這么看是看不出有啥關(guān)系的,但是,我們可以從另外的一個(gè)位置
這樣看下來(lái),這個(gè) Neo4J 簡(jiǎn)單操作是不是就學(xué)會(huì)了,阿粉接下來(lái)的文章中講怎么使用 Java 來(lái)操作 Neo4J 數(shù)據(jù)庫(kù)。歡迎大家來(lái)觀看。
nosql數(shù)據(jù)庫(kù)的四種類型如下:
1.key-value鍵值存儲(chǔ)數(shù)據(jù)庫(kù):
相關(guān)產(chǎn)品: Redis、Riak、SimpleDB、Chordless、Scalaris、Memcached.
主要應(yīng)用: 內(nèi)容緩存,處理大量數(shù)據(jù)的高負(fù)載訪問(wèn),也用于系統(tǒng)日志。
優(yōu)點(diǎn):查找速度快,大量操作時(shí)性能高。
2.列存儲(chǔ)數(shù)據(jù)庫(kù):
相關(guān)產(chǎn)品: BigTable、HBase、Cassandra、HadoopDB、GreenPlum、PNUTS.
主要應(yīng)用: 分布式數(shù)據(jù)的儲(chǔ)存與管理。
優(yōu)點(diǎn):查找速度快,可擴(kuò)展性強(qiáng),容易進(jìn)行分布式擴(kuò)展。
缺點(diǎn):功能相對(duì)局限。
3.文檔型數(shù)據(jù)庫(kù)
相關(guān)產(chǎn)品:MongoDB、CouchDB、ThruDB、CloudKit、Perservere、Jackrabbit.
主要應(yīng)用: web應(yīng)用,管理面向文檔的數(shù)據(jù)或者類似的半結(jié)構(gòu)化數(shù)據(jù)。
優(yōu)點(diǎn):數(shù)據(jù)結(jié)構(gòu)靈活,表結(jié)構(gòu)可變,復(fù)雜性低。
缺點(diǎn):查詢效率低,且缺乏統(tǒng)一的查詢語(yǔ)言。
4.Graph圖形數(shù)據(jù)庫(kù)
相關(guān)產(chǎn)品: Neo4J、OrientDB、InfoGrid、GraphDB.
主要應(yīng)用: 復(fù)雜,互連接,低結(jié)構(gòu)化的圖結(jié)構(gòu)場(chǎng)合, 專注構(gòu)建關(guān)系圖譜。
優(yōu)點(diǎn): 利用圖結(jié)構(gòu)相關(guān)算法, 可用于構(gòu)建復(fù)雜的關(guān)系圖譜。
缺點(diǎn): 復(fù)雜度高。
不是。
redis是一個(gè)key-value的nosql數(shù)據(jù)庫(kù)(非關(guān)系型數(shù)據(jù)庫(kù))。支持存儲(chǔ)的value類型包括string(字符串)、list(鏈表)、set(集合)、zset(sorted set --有序集合)和hash(哈希類型)。
這些數(shù)據(jù)類型都支持push/pop、add/remove及取交集并集和差集及更豐富的操作,而且這些操作都是原子性的。為了保證效率,數(shù)據(jù)都是緩存在內(nèi)存中。
MySQL是關(guān)系型數(shù)據(jù)庫(kù),主要用于存放持久化數(shù)據(jù),將數(shù)據(jù)存儲(chǔ)在硬盤中,讀取速度較慢。
Redis是NOSQL,即非關(guān)系型數(shù)據(jù)庫(kù),也是緩存數(shù)據(jù)庫(kù),即將數(shù)據(jù)存儲(chǔ)在緩存中,緩存的讀取速度快,能夠大大的提高運(yùn)行效率,但是保存時(shí)間有限。
Redis和MySQL的區(qū)別:
1、類型上
從類型上來(lái)說(shuō),MySQL是關(guān)系型數(shù)據(jù)庫(kù),Redis是緩存數(shù)據(jù)庫(kù)。
2、作用上
MySQL用于持久化的存儲(chǔ)數(shù)據(jù)到硬盤,功能強(qiáng)大,但是速度較慢。
Redis用于存儲(chǔ)使用較為頻繁的數(shù)據(jù)到緩存中,讀取速度快。
3、需求上
MySQL和Redis因?yàn)樾枨蟮牟煌?一般都是配合使用。
4、場(chǎng)景選型上
Redis和MySQL要根據(jù)具體業(yè)務(wù)場(chǎng)景去選型。
5、存放位置
數(shù)據(jù)存放位置MySQL:數(shù)據(jù)放在磁盤。
Redis:數(shù)據(jù)放在內(nèi)存。
6、適合存放數(shù)據(jù)類型
Redis適合放一些頻繁使用,比較熱的數(shù)據(jù),因?yàn)槭欠旁趦?nèi)存中,讀寫速度都非???一般會(huì)應(yīng)用在下面一些場(chǎng)景:排行榜、計(jì)數(shù)器、消息隊(duì)列推送、好友關(guān)注、粉絲。