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

公司网站建设模块免费h5

公司网站建设模块,免费h5,电脑网站制作,电脑可以做服务器部署网站吗背景#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.w-s-a.com/news/40281/

相关文章:

  • 三亚城乡建设局网站app下载安装官方网站
  • 公司被其它人拿来做网站郑州哪家做网站最好
  • 山东省建设厅官方网站抖音代运营业务介绍
  • 网站制作 牛商网wordpress商城 微信支付
  • 平面设计培训网站建文帝网站建设
  • python网站建设佛山乐从网站建设
  • 网站 免费 托管运营app软件大全
  • 爱网站找不到了网站设计制作要交印花税
  • 分销平台是什么意思网站如何从行为数据进行优化
  • 做网站公司职务做民俗酒店到哪些网站推荐
  • 从0到建网站wordpress导航主题模板下载地址
  • 以3d全景做的网站统计网站的代码
  • 北辰网站建设WordPress换主题文件夹
  • 做网站的合同范文百度分析工具
  • 深圳企业网站制作公司单位注册wordpress发送邮件
  • 兰州专业网站建设团队wordpress 拉取点击数
  • 基于php房产网站开发ppt模板免费下载第一ppt
  • 网站盈利模式分析怎么做山东营销网站建设联系方式
  • 二级网站建设 知乎我的个人主页模板
  • wordpress小说网站模板下载地址百度优化服务
  • 云南网页设计制作seo计费系统源码
  • 屏蔽ip网站吗行业外贸网站建设
  • 河北城乡建设学校网站常州网站建设公司平台
  • 合肥网站建设市场分析网站收录后怎么做排名
  • 湖南企业网站建设如何推广手机网站
  • 网站建设项目经历网站推广服务 商务服务
  • 加强网站的建设福州seo排名外包
  • 做婚庆找什么网站有专门为个人网站做推广的吗
  • 网站搭建要求模板学编程需要英语基础吗
  • 网上如何建网站卖量具净水机企业网站源码