NEO4J(数据存入尝试)

2018-05-11
用Cyher语句进行少量数据存入,目的在于需求合适的数据模型。
缺乏相关理论指导,只能通过尝试来发现寻找合适的方案了

  1. Cypher 存入一个节点的语法示例为:
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})

可以看到属性部分的格式为

key1:value2,key2:value2,...

之前通过API取得的数据为

MainSense: WN:EN:Vietnam
POS:NOUN
iskeyConcept: false
Sense: WN:EN:Vietnam
Sense: WN:EN:Socialist_Republic_of_Vietnam
...
Sense: WIKIRED:EN:Red_Vietnam_(modern)
glosses: A communist state in Indochina on the South China Sea; achieved independence from France in 1945
glosses: Vietnam, officially the Socialist Republic of Vietnam, is the easternmost country on the Indochina Peninsula in Southeast Asia.
...
glosses: Country in Southeast Asia.
glosses: Vietnam is a country in East Asia.
Image: <a href="https://upload.wikimedia.org/wikipedia/commons/d/d6/Location_Vietnam_ASEAN.svg">Location_Vietnam_ASEAN.svg#OMWIKI</a>
Image: <a href="https://upload.wikimedia.org/wikipedia/commons/8/80/Asia_%28orthographic_projection%29.svg">Asia_(orthographic_projection).svg#OMWIKI</a>
...
Image: <a href="https://upload.wikimedia.org/wikipedia/commons/5/5f/Flag_of_Quebec.svg">Flag_of_Quebec.svg#WIKIDATA</a>
Image: <a href="https://upload.wikimedia.org/wikipedia/commons/4/4b/Flag_of_Libya_%281977-2011%29.svg">Flag_of_Libya_(1977-2011).svg#WIKIDATA</a>
Image: <a href="https://upload.wikimedia.org/wikipedia/commons/3/34/Red_star.svg">Red_star.svg#WIKIDATA</a>
Category: BNCAT:EN:1976_establishments_in_Vietnam
Category: BNCAT:EN:Communist_states
...
Category: BNCAT:EN:Vietnam
Category: BNCAT:EN:Vietnamese-speaking_countries_and_territories

想要直接复制粘贴成Cypher命令的一部分就需要对数据格式进行调整
可以选择

  1. 直接调整获取数据的java程序,格式化输出,再次获取数据
    2.对以获取的数据直接进行格式调整
    我选择用方法2,通过VIM调整数据格式

在normal模式下

gg      #指针到文档开头
q1      #进入寄存器
^Wi'<Esc>$a',<Esc>j   #录入指令
q        #离开寄存器
10000@1        #调用寄存器1中的指令10000次

得到格式化后的结果

MainSense: 'WN:EN:Vietnam',
POS:'NOUN',
iskeyConcept: 'false',
Sense: 'WN:EN:Vietnam',
Sense: 'WN:EN:Socialist_Republic_of_Vietnam',
Sense: 'WN:EN:Viet_Nam',
Sense: 'WN:EN:Annam',
Sense: 'GEONM:EN:Socialist_Republic_of_Vietnam',
Sense: 'GEONM:EN:Vietnam',
Sense: 'WIKI:EN:Vietnam',
Sense: 'WIKIDATA:EN:How_to_contribute',
Sense: 'WIKIDATA:EN:How_to_contribute',
Sense: 'WIKIDATA:EN:Socialist_Republic_of_Vietnam',
...

将结果粘贴至Cypher语句属性部分创建节点

CREATE (vietnam:Country {id:'bn:00004315n', name:'vietnam',
MainSense: 'WN:EN:Vietnam',
POS:'NOUN',
iskeyConcept: 'false',
Sense: 'WN:EN:Vietnam',
Sense: 'WN:EN:Socialist_Republic_of_Vietnam',
Sense: 'WN:EN:Viet_Nam',
...
})

这里提示语法错误
发现是原始数据中单引号干扰了Cypher语句中字符串的划分
解决方法:先在原始数据中,将每一个单引号前都加上转义符变成\',然后再调整格式。

成功存入后查看结果。

match.png

观察发现结果并不正确
同名属性被覆盖!!每个属性名都只保留了最后一条记录!
解决方法:将多值属性以数组的形式实现保存

CREATE (vietnam:Country {id:'bn:00004315n', name:'vietnam',
MainSense: 'WN:EN:Vietnam',
POS:'NOUN',
iskeyConcept: 'false',
Sense:[ 'WN:EN:Vietnam',
        'WN:EN:Socialist_Republic_of_Vietnam',
        'WN:EN:Viet_Nam',
        ...],
Image:[ '<a href="https://upload.wikimedia.org/wikipedia/commons/d/d6/Location_Vietnam_ASEAN.svg">Location_Vietnam_ASEAN.svg#OMWIKI</a>',
        '<a href="https://upload.wikimedia.org/wikipedia/commons/8/80/Asia_%28orthographic_projection%29.svg">Asia_(orthographic_projection).svg#OMWIKI</a>',
        '<a href="https://upload.wikimedia.org/wikipedia/commons/6/63/Location_of_Asia.svg">Location_of_Asia.svg#OMWIKI</a>',
        ...]
})

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • rljs by sennchi Timeline of History Part One The Cognitiv...
    sennchi阅读 7,436评论 0 10
  • 2018-05-10 主要的类包括 BabelNet BabelSynset BabelSense BabelNe...
    冰镇果汁加点糖阅读 1,381评论 1 0
  • 逍遥游,是最爱的古文之一了;可惜还不得要领,抄抄写写,慢慢领会要义。
    TrueFar阅读 149评论 2 3
  • 月光是一个小姑娘,她清冷,高傲,却又孤独。月光最爱在月光底下静坐着,或发呆或低声吟唱,她的歌声悠远,似从空中来,沁...
    你你_85b6阅读 260评论 0 0
  • 你从我的坟前走过 ——南生 2017.2.23 在开满鲜花的时节 荆棘鸟为我歌唱 歌唱你 从我的坟前走过 石碑、把...
    南生刘成阅读 433评论 0 2