neo4j使用示例总结
一. 同步neo4j数据
配置jdk(让dba安装neo4j的时候配置一下)
JAVA_HOME=/usr/local/jdk-11.0.10
CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib
PATH=$JAVA_HOME/bin:$PATH
source /etc/profile 让jdk配置生效
进入neo4j执行目录/usr/local/neo4j/bin 停用neo4j, ./neo4j stop
将cmdbd.dump文件拷入目标服务的/tmp目录(记得修改owner权限为root)u
进入neo4j执行目录/usr/local/neo4j/bin,执行导入操作 ./neo4j-admin load --from=cmdbd.dump --database=cmdu --force(如果是备份数据执行./neo4j-admin dump --database=cmdu --to=/tmp/cmdbd.dump)
启用./neo4j start
二. 清除neo4j数据库数据
登录neo4j网页版 http://10.101.11.191:7474/browser/
然后执行语句: match (n) detach delete n
三. 索引
删除索引 DROP INDEX ON :ModelEntity(code)
创建索引 CREATE INDEX ON :ModelEntity(code)
查看索引 :schema
查看执行耗时 MATCH p =(n:ResourceEntity{code: 'CI_0000885001'})-[*0..]-(m:ResourceEntity) RETURN m
查看执行计划 explain MATCH p =(n:ResourceEntity{code: 'CI_0000885001'})-[*0..]-(m:ResourceEntity) RETURN m
索引建立后状态为Populating,要重启数据库并关闭才会生效。可用“:schema”指令查看索引是否是ONLINE状
控制查询层级为3层
MATCH p =(n:ResourceEntity{code: 'CI_0000885001'})-[*0..3]-(m:ResourceEntity) RETURN m
控制查询层级为2层
MATCH p =(n:ResourceEntity{code: 'CI_0000885001'})-[*0..2]-(m:ResourceEntity) RETURN m