当前位置: 首页 > news >正文

湖北网站建站系统哪家好作文网站网址

湖北网站建站系统哪家好,作文网站网址,代做网站平台,网络推广如何有效背景#xff1a;我们项目第一次部署图数据库#xff0c;要求我们把现有的业务数据以及关系上线第一时间初始化到Neo4j中。开发环境数据量已经百万级别。生成环境数据量更多。 我刚开始开发的时候#xff0c;由于对Neo4j的了解并没有很多#xff0c;第一想到的是用代码通用组… 背景我们项目第一次部署图数据库要求我们把现有的业务数据以及关系上线第一时间初始化到Neo4j中。开发环境数据量已经百万级别。生成环境数据量更多。 我刚开始开发的时候由于对Neo4j的了解并没有很多第一想到的是用代码通用组装create语句进行创建节点以及关系。 业务说明系统中有很多实体表每个实体表中有自己的数据不同实体有一张关系表进行维护。 我开发的思路是1.先将所有的表中数据取出来做为节点 2.根据关系表将这个数据的关系查出来之后组装语句将数据添加到Neo4j中。 具体代码如下Springboot项目版本2.2.5RELEASE pom.xml dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-neo4j/artifactId/dependency配置文件进行下面配置 spring:data:neo4j:uri: bolt://localhost:7687username: neo4jpassword: neo4j使用Java代码组装CQL语句用原生session进行 Neo4jConfig.java Configuration public class Neo4jConfig {Value(${spring.data.neo4j.uri})private String uri;Value(${spring.data.neo4j.username})private String userName;Value(${spring.data.neo4j.password})private String password;Beanpublic org.neo4j.ogm.config.Configuration getConfiguration() {org.neo4j.ogm.config.Configuration configuration new org.neo4j.ogm.config.Configuration.Builder().uri(uri).connectionPoolSize(100).credentials(userName, password).withBasePackages(com.troy.keeper.desc.repository).build();return configuration;}Beanpublic SessionFactory sessionFactory() {return new SessionFactory(getConfiguration());}Bean(neo4jTransaction)public Neo4jTransactionManager neo4jTransactionManager(SessionFactory sessionFactory) {return new Neo4jTransactionManager(sessionFactory);}接口入口Controller.java GetMapping(initDataToNeo4j)public void initDataToNeo4j() {service.initDataToNeo4j();}Service.java //节点数据按照自己的实际业务添加我这里对应的是所有表的数据因为我业务中所有表结果基本一样也即节点属性都一样。每个表的数据一个map,key是表名作为节点的标签 MapString, ListNodeData nodeDataMap; //关系数据将每一个表数据的关系作为RelationData实体 ListRelationData relationDatas;//数据组装完成后进行节点的创建 neo4jUtil.creatNode(nodeDataMap);//进行关系绑定 neo4jUtil.bindRelation(relationDatas);NodeData.java private String id;//属性id private String name;//属性名称 private String table;//作为节点标签RelationData.java //关系id private String id; //关系名称 private String relationName; //因为我这里的关系跨实体所以需要指定结束标签 private String endLableName;//因为我这里的关系跨实体所以需要指定开始标签 private String startLableName;//开始节点的值 private String startValue;//结束节点的值 private String endWhereValue;Neo4jUtil.java Component public class Neo4jUtil { Resource private Session session; /*** 删除标签下的节点(包括节点之间的关系)* param lableName* return*/public Integer deleteByLable(String lableName) {if (StringUtils.isEmpty(lableName)) {return 0;}String cypherSql String.format(MATCH (r:%s) DETACH DELETE r , lableName);Result query session.query(cypherSql, new HashMap(16));session.clear();return query.queryStatistics().getNodesDeleted();}//创建节点 public void creatNode(MapString, ListNodeData nodeDataMap) {if (nodeDataMap null) {return ;}for(String key:nodeDataMap.keySet()){ListNodeData data nodeDataMap.get(key);if (StringUtils.isEmpty(key)) {continue;}//表下没有数据的只创建一个没有属性的节点if (data null || data.isEmpty()) {String sql String.format(create (:%s),key);session.query(sql, new HashMap(16));continue;}//因为是全量导入可以先删除这个标签下的全部节点和关系,按照自己业务要求自行添加deleteByLable(key);for (NodeData nodeData:data) {//兼容中文和特殊符号String labels : String.join(:, key) ;;String id nodeData.getId();String name nodeData.getName();String property String.format({id:%s,name:%s} , id,name);String sql String.format(create (%s%s), labels, property);session.query(sql, new HashMap(16));}}}//绑定关系 public void bindRelation( ListRelationData relations) {if (relations null) {return;}for (RelationData relation:relations) {String id relation.getId();String relationName relation.getRelationName();String startLableName relation.getStartLableName();String endLableName relation.getEndLableName();String startValue relation.getStartValue();String endValue relation.getEndValue();String property String.format({id:%s,name:%s} , id,relationName);String cypherSql String.format(MATCH (n:%s),(m:%s) where n.id %s and m.id %s CREATE (n)-[r:%s%s]-(m),startLableName,endLableName,startValue ,endValue ,relationName,property) ;session.query(cypherSql, new HashMap(16));}} }之后执行controller接口进行数据抽取和导入Neo4j我开发的时候用的环境大约有7w个节点120w条关系。用本地Neo4j跑了两个多小时连服务器部署的(跨地区)跑了8个小时。。。。 太慢了 后来查资料说是create适合数据量小的时候用对于大量数据导入可以用neo4j-admin import 接下来改造用neo4j-admin import 参见Java初始化数据到Neo4j中(二)
http://www.dnsts.com.cn/news/102710.html

相关文章:

  • 网站宣传工作ui设计包括哪些场景
  • 空间站做网站有什么免费申请网站首选百度
  • 普法网站建设自己做简历网站
  • 苏州企业网站建设电话合肥市蜀山区做个网站多少钱
  • 女生做网站前台c 网站开发htnl
  • 建设医院的网站重庆网站公司
  • 衡阳网站建设要点推广品牌形象设计毕业设计
  • 检测一个网站用什么软件做的方法各大网站博客怎么做推广
  • 淘宝客模板 带程序自动采集 淘宝客网站源码 最新懒人淘宝客源码seo是如何做优化的
  • 佛山企业网站建设教程建设厅网站举报
  • 优秀网站设计作品分析积分动力WordPress
  • 建设电影网站选服务器怎么选设计坞官网首页
  • 花都建站嘉兴房产网站建设
  • 网站开发程序的移交承德信息网络有限公司
  • 哪有网站建设的wordpress注册提示
  • 天津网站备案去哪社交网站盈利吗
  • 旅游网站优化方案未来对网站建设的需求
  • 网站运营需要哪些技术东营网站建设seo
  • 做网站后有人抢注关键词表白视频制作
  • 网站广告制作wordpress 4.5 中文404
  • 学生个人网站模板手机网站建设视频
  • 网站如何转移到新的空间服务器上试述网站建设应考虑哪些方面的问题
  • 郑州网站建设商城定制网站建设常用字体
  • 襄州区住房和城乡建设局网站常州互联网公司
  • 广东城乡住房建设部网站app手机端电子商务网站功能
  • 学校网站建设调查问卷网站建设最好
  • 如何注册网站自助定制网站开发公司
  • 制作企业网站的报告网络营销方式都有哪些
  • 优秀室内设计案例seo公司哪家便宜
  • 怎么建设自己网站的后台川沙网站建设