CYPHER 語句(Neo4j)


CYPHER 語句(Neo4j)

 

創建電影關系圖

CREATE (TheMatrix:Movie {title:'The Matrix', released:1999, tagline:'Welcome to the Real World'})
CREATE (Keanu:Person {name:'Keanu Reeves', born:1964})
CREATE (Carrie:Person {name:'Carrie-Anne Moss', born:1967})
CREATE (Laurence:Person {name:'Laurence Fishburne', born:1961})
CREATE (Hugo:Person {name:'Hugo Weaving', born:1960})
CREATE (LillyW:Person {name:'Lilly Wachowski', born:1967})
CREATE (LanaW:Person {name:'Lana Wachowski', born:1965})
CREATE (JoelS:Person {name:'Joel Silver', born:1952})
CREATE
  (Keanu)-[:ACTED_IN {roles:['Neo']}]->(TheMatrix),
  (Carrie)-[:ACTED_IN {roles:['Trinity']}]->(TheMatrix),
  (Laurence)-[:ACTED_IN {roles:['Morpheus']}]->(TheMatrix),
  (Hugo)-[:ACTED_IN {roles:['Agent Smith']}]->(TheMatrix),
  (LillyW)-[:DIRECTED]->(TheMatrix),
  (LanaW)-[:DIRECTED]->(TheMatrix),
  (JoelS)-[:PRODUCED]->(TheMatrix)
  
CREATE (Emil:Person {name:"Emil Eifrem", born:1978})
CREATE (Emil)-[:ACTED_IN {roles:["Emil"]}]->(TheMatrix)

CREATE (TheMatrixReloaded:Movie {title:'The Matrix Reloaded', released:2003, tagline:'Free your mind'})
CREATE
  (Keanu)-[:ACTED_IN {roles:['Neo']}]->(TheMatrixReloaded),
  (Carrie)-[:ACTED_IN {roles:['Trinity']}]->(TheMatrixReloaded),
  (Laurence)-[:ACTED_IN {roles:['Morpheus']}]->(TheMatrixReloaded),
  (Hugo)-[:ACTED_IN {roles:['Agent Smith']}]->(TheMatrixReloaded),
  (LillyW)-[:DIRECTED]->(TheMatrixReloaded),
  (LanaW)-[:DIRECTED]->(TheMatrixReloaded),
  (JoelS)-[:PRODUCED]->(TheMatrixReloaded)

  (Keanu)-[:ACTED_IN {roles:['Julian Mercer']}]->(SomethingsGottaGive),
  (NancyM)-[:DIRECTED]->(SomethingsGottaGive),
  (NancyM)-[:PRODUCED]->(SomethingsGottaGive),
  (NancyM)-[:WROTE]->(SomethingsGottaGive) 

查找

查看節點所有屬性

match (n:LOGIC_SUBJECT) unwind keys(n) as key return distinct key;

 

屬性查找

#查找無age屬性的節點
match(n:Person) WHERE n.age is not null RETURN n #查找有age屬性的節點 match(n:Person) WHERE n.age is null RETURN n

查找兩個節點是否存在多個相同關系

match(m)-[r]-(n) where size((m)-[:relationship]-(n))>1 return *

模糊查找

#查找name中以"J"開頭的內容
match(n:Person) where n.NAME=~ 'J.*' return n

查詢標簽屬性信息

match (n:場景) unwind keys(n) as key return distinct key;

 

 

新增

新增節點

#新增Jack T 和 Tom T 兩個人
create (:Person{name:'Jack T'}),(:Person{name:'Tom T'}) match(m:Person{name:'Jack T'}),(n:Person{name:'Tom T'}) return n,m

 

 

新增邊

#Jack T 是Tom T的朋友
match(m:Person{name:'Jack T'}),(n:Person{name:'Tom T'}) create (m)-[r:friend_to]->(n) return n,r,m

 

 

新增屬性

match(n:Person) where n.name='Jack T'  set n+={age:15} return n

 

 

修改

修改屬性

#單個節點
match(n:Person) where n.name='Keanu Reeves' set n.age=16 return n

#批量節點 如果沒有改屬性,則會新增
match(n:Person) set n.age=16 return n

 復制屬性

match (m { name:'Keanu Reeves' }),(n { name: 'Hugo Weaving' }) set n = m return n,m

 修改節點名稱

match(n:INTERFACE) set n:T_BDM_ITFS
match(n:T_BDM_ITFS) remove  n:INTERFACE

 

字符串處理

截取部分字符串

MATCH (n:LOGIC_SUBJECT) RETURN substring(n.NAME,0,4)

 

 

 

刪除

 刪除屬性

#單個節點刪除屬性
match(n:Person) where n.age=17 remove n.age

#批量刪除屬性
match(n:Person) remove n.age

 

導入

CSV文件

#import 文件夾下
load
csv with headers from 'file:///fileName.csv' as newLables create(n:LableNewName) set Lable = newLables

LOAD CSV FROM 'file:///abc.csv' AS line
CREATE (:T_BDM_PANORAMA {name: line[2], sid:line[1]})

 

 格式轉換

LOAD CSV FROM 'https://neo4j.com/docs/developer-manual/3.3/csv/artists.csv' AS line
#字符串轉換成整型 toInteger
CREATE (:Artist { name: line[1], year: toInteger(line[2])})

 

數據遷移

match(n:PROJECT_SG_CIM3_5) return n.name as name,id(n) as oldID;

match(n:PROJECT_SG_CIM3_5)-[r]->(m:PROJECT_SG_CIM3_5) return id(startNode(r)) as startId_BUS_CLASS,id(endNode(r)) as endId_BUS_CLASS;

load csv with headers from "file:///a661.csv" as row match (n:LOGIC_OBJECT{oldID:row.startId_BUS_CLASS}),(m:LOGIC_OBJ_DETAIL{oldID:row.endId_BUS_CLASS}) create (n)-[:LOG_OBJ_TO_OBJ_DET]->(m);

LOAD CSV WITH HEADERS  FROM "file:///label.csv" AS line
create (:SYS{id:line.ID,name:line.NAME})

load csv with headers from "file:///relation.csv" as row match (n:SYS{id:row.first}),(m:SYS{id:row.second})
create (n)-[:LINE{name:row.NAME}]->(m);

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM