此插件对应版本:NEO4J-3.5.X
PLUGIN安装:MAVEN INSTALL之后在target目录下生成的JAR包安装到NEO4J安装目录下的PLUGIN目录,将dic文件夹移动到NEO4J安装根目录即可。
中文分词:需要新增的词表在user_defined.dic新增或者在cfg.xml文件中配置即可
# 版本信息:
LUCENE-5.5.0
IKAnalyzer-5.0
过程:用 Call com.xxxx.xx (参数)来调用执行。
函数:可以用在cypher中任何可以使用方法的地方如where子句,return子句中。如match (n) wehre com.xxx.xx(n) return n。
1、计算IDS中ID的个数
RETURN zdr.apoc.getEventIdsSize("123123,123123,2131,12321,23424,123123,2331") as value
match p=(n:LABEL1)<-[r:REL]-(m:LABEL2) where n.name='新闻_1432' and r.eventTargetIds IS NOT NULL return p ORDER BY zdr.apoc.getEventIdsSize(r.eventTargetIds) DESC limit 10
2、列表数字降序排列
RETURN zdr.apoc.sortDESC([4,3,5,1,6,8,7]) as descList
3、打印HELLO WORLD
RETURN zdr.apoc.hello("world") as greeting
4、创建测试节点
CALL zdr.apoc.createCustomer('Test') YIELD node RETURN node
5、离差标准化函数
zdr.apoc.scorePercentage
6、移动小数点
zdr.apoc.moveDecimalPoint
7、中文分词 *-true 智能分词,false 细粒度分词
RETURN zdr.index.iKAnalyzer('复联终章快上映了好激动,据说知识图谱与人工智能技术应用到了那部电影!吖啶基氨基甲烷磺酰甲氧基苯胺是一种药嘛?',true) AS words
8、创建中文全文索引(不同标签使用相同的索引名即可支持跨标签类型检索)
CALL zdr.index.addChineseFulltextIndex('IKAnalyzer', ['description'], 'Loc') YIELD message RETURN message
CALL zdr.index.addChineseFulltextIndex('IKAnalyzer',['description','year'], 'Loc') YIELD message RETURN message
CALL zdr.index.addChineseFulltextIndex('IKAnalyzer', ['description','year'],'LocProvince') YIELD message RETURN message
9、中文全文索引查询(可跨标签类型检索)- *-1表示数据量不做限制返回全部 *-lucene查询示例
CALL zdr.index.chineseFulltextIndexSearch('IKAnalyzer', 'description:吖啶基氨基甲烷磺酰甲氧基苯胺', 100) YIELD node RETURN node
CALL zdr.index.chineseFulltextIndexSearch('IKAnalyzer', 'description:吖啶基氨基甲烷磺酰甲氧基苯胺', 100) YIELD node,weight RETURN node,weight
CALL zdr.index.chineseFulltextIndexSearch('IKAnalyzer', 'description:吖啶基氨基甲烷磺酰甲氧基苯胺', -1) YIELD node,weight RETURN node,weight
CALL zdr.index.chineseFulltextIndexSearch('IKAnalyzer', '+(description:复联) AND -(_entity_name:美国)',10) YIELD node,weight RETURN node,weight
CALL zdr.index.chineseFulltextIndexSearch('IKAnalyzer', '+(site_name:东方网) OR +(_entity_name:东方网)',10) YIELD node,weight RETURN node,weight
-- 包含小和合 不包含婷、诗和Jason Lim
CALL zdr.index.chineseFulltextIndexSearch('IKAnalyzer', '_entity_name:(+小 +合 -"婷" -诗 -"Jason Lim")',10) YIELD node,weight RETURN node,weight
-- 范围查询
CALL zdr.index.chineseFulltextIndexSearch('IKAnalyzer', '+(name:东方网) AND +(testTime:[1582279892461 TO 1582279892461])',10) YIELD node,weight RETURN node,weight
10、为节点添加索引
MATCH (n) WHERE n.name='A' WITH n CALL zdr.index.addNodeChineseFulltextIndex(n, ['description']) RETURN *
11、生成JSON-从CYPHER直接生成JSON【支持节点转换/属性转换/路径转换】
match (n) return casia.convert.json(n) limit 10
match p=(n)-[]-() return casia.convert.json(p) limit 1
match (n) return casia.convert.json(properties(n)) limit 10
12、更多过程与函数请参考源码和测试...
分词步骤:词典加载、预处理、分词器分词、歧义处理、结尾处理(处理遗漏中文字符/处理数量词)
分词模式:SMART模式(歧义判断)与非SMART模式(最小力度的分词)
具体的实例:
张三说的确实在理
smart模式的下分词结果为:
张三 | 说的 | 确实 | 在理
而非smart模式下的分词结果为:
张三 | 三 | 说的 | 的确 | 的 | 确实 | 实在 | 在理