Nebula Graph - SpringBoot 操作 Nebula

举报
程序员-上善若水 发表于 2022/06/23 23:08:03 2022/06/23
【摘要】 一、Nebula Graph 前面两篇文章,讲解了下 Nebula Graph 的安装,及 nGQL 的使用,本篇文章讲解下在 java 环境下如何对 Nebula Graph 进行操作,使用 Spri...

一、Nebula Graph

前面两篇文章,讲解了下 Nebula Graph 的安装,及 nGQL 的使用,本篇文章讲解下在 java 环境下如何对 Nebula Graph 进行操作,使用 SpringBoot 环境。

下面是上篇文章的地址:

https://blog.csdn.net/qq_43692950/article/details/124579284

二、SpringBoot 操作 Nebula Graph

  • 首先引入 pom 依赖:

    <dependency>
        <groupId>com.vesoft</groupId>
        <artifactId>client</artifactId>
        <version>3.0.0</version>
    </dependency>
    
        
       

    为方便解析 json ,这里把 fastjson 也引进来。

    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>fastjson</artifactId>
        <version>1.2.78</version>
    </dependency>
    
        
       
  • 配置文件中配置 Nebula 的信息,后面读取这里的配置信息。

    nebula:
      address[0]:
        host: 192.168.40.130
        port: 9669
      username: root
      password: root
      reconnect: false
      space: javatest
    
        
       
  • 声明 NebulaProperties 接收上面的配置信息:

    @Data
    public class NebulaAddress {
        private String host;
        private Integer port;
    }
    
        
       
    @Data
    @Configuration
    @ConfigurationProperties(prefix = "nebula")
    public class NebulaProperties {
        private List<NebulaAddress> address;
        private String username;
        private String password;
        private boolean reconnect;
        private String space;
    }
    
        
       
  • 声明 NebulaConstant 把常用的字符串声明在这里:

    public class NebulaConstant {
        public static final String USE = "USE ";
        public static final String SEMICOLON = "; ";
        public static final String ERROR_CODE = "-1";
    
        @Getter
        @AllArgsConstructor
        public enum NebulaJson{
            ERRORS("errors"),
            CODE("code"),
            MESSAGE("message"),
            RESULTS("results"),
            COLUMNS("columns"),
            DATA("data"),
            ROW("row");
            private String key;
        }
    }
    
        
       
  • 声明 NebulaConfig ,初始化 NebulaPool ,及声明 Session 的获取方式:

    @Slf4j
    @Configuration
    public class NebulaConfig {
    
        @Bean
        public NebulaPool nebulaPool(NebulaProperties properties) throws UnknownHostException {
            NebulaPool pool = new NebulaPool();
            NebulaPoolConfig nebulaPoolConfig = new NebulaPoolConfig();
            nebulaPoolConfig.setMaxConnSize(1000);
            boolean init = pool.init(properties.getAddress().stream().map(d -> new HostAddress(d.getHost(), d.getPort())).collect(Collectors.toList()), nebulaPoolConfig);
            if (!init){
                throw new RuntimeException("NebulaGraph init err !");
            }else {
                log.info("NebulaGraph init Success !");
            }
            return pool;
        }
    
        @Bean
        @Scope(scopeName = "prototype",proxyMode = ScopedProxyMode.TARGET_CLASS)
        public Session session(NebulaPool nebulaPool,NebulaProperties properties) {
            try {
                Session session = nebulaPool.getSession(properties.getUsername(), properties.getPassword(), properties.isReconnect());
                session.execute(StringFormatter.concat(NebulaConstant.USE, properties.getSpace(), NebulaConstant.SEMICOLON).getValue());
                return session;
            } catch (Exception e) {
                log.error("get nebula session err , {} ", e.toString());
            }
            return null;
        }
    }
    
        
       
  • 为了方便对结果的解析,再声明一个 NebulaResult 用来接收结果:

    @Data
    public class NebulaResult<T> {
        private Integer code;
        private String message;
        private List<T> data;
    
        public boolean isSuccessed(){
            return code == 0;
        }
    }
    
        
       
  • 每次都是使用 Session 未免太麻烦,这里封装一个 NebulaTemplate 返回上面 对象 :

    @Slf4j
    @Component
    public class NebulaTemplate {
    
        @Resource
        Session session;
    
        public <T> NebulaResult<T> queryObject(String stmt, Class<T> tClass) {
            NebulaResult<T> nebulaResult = executeObject(stmt);
            if (Objects.isNull(nebulaResult.getData())) {
                return nebulaResult;
            }
            Optional.ofNullable(nebulaResult.getData()).ifPresent(data -> nebulaResult.setData(data.stream().map(d -> JSONObject.toJavaObject(((JSONObject) d), tClass)).collect(Collectors.toList())));
            return nebulaResult;
        }
    
        public NebulaResult executeObject(String stmt) {
            JSONObject jsonObject = executeJson(stmt);
            return JSONObject.toJavaObject(jsonObject, NebulaResult.class);
        }
    
        public JSONObject executeJson(String stmt) {
            JSONObject restJson = new JSONObject();
            try {
                JSONObject jsonObject = JSON.parseObject(Objects.requireNonNull(session).executeJson(stmt));
                JSONObject errors = jsonObject.getJSONArray(NebulaConstant.NebulaJson.ERRORS.getKey()).getJSONObject(0);
                restJson.put(NebulaConstant.NebulaJson.CODE.getKey(), errors.getInteger(NebulaConstant.NebulaJson.CODE.getKey()));
                if (errors.getInteger(NebulaConstant.NebulaJson.CODE.getKey()) != 0) {
                    restJson.put(NebulaConstant.NebulaJson.MESSAGE.getKey(), errors.getString(NebulaConstant.NebulaJson.MESSAGE.getKey()));
                    return restJson;
                }
                JSONObject results = jsonObject.getJSONArray(NebulaConstant.NebulaJson.RESULTS.getKey()).getJSONObject(0);
                JSONArray columns = results.getJSONArray(NebulaConstant.NebulaJson.COLUMNS.getKey());
                if (Objects.isNull(columns)) {
                    return restJson;
                }
                JSONArray data = results.getJSONArray(NebulaConstant.NebulaJson.DATA.getKey());
                if (Objects.isNull(data)) {
                    return restJson;
                }
                List<JSONObject> resultList = new ArrayList<>();
                data.stream().map(d -> (JSONObject) d).forEach(d -> {
                    JSONArray row = d.getJSONArray(NebulaConstant.NebulaJson.ROW.getKey());
                    JSONObject map = new JSONObject();
                    for (int i = 0; i < columns.size(); i++) {
                        map.put(columns.getString(i), row.get(i));
                    }
                    resultList.add(map);
                });
                restJson.put(NebulaConstant.NebulaJson.DATA.getKey(), resultList);
            } catch (Exception e) {
                restJson.put(NebulaConstant.NebulaJson.CODE.getKey(), NebulaConstant.ERROR_CODE);
                restJson.put(NebulaConstant.NebulaJson.MESSAGE.getKey(), e.toString());
                log.error("nebula execute err:", e);
            }
            return restJson;
        }
    }
    
        
       
  • 测试

    @RestController
    public class TestController {
    
        @Resource
        NebulaTemplate nebulaTemplate;
    
        @GetMapping("/addVertex")
        public Object addJSON() throws IOErrorException {
            String sql = "insert vertex team(team_name, persion_num) values \"team_2\":(\"team_2\", 43);";
            NebulaResult nebulaResult = nebulaTemplate.executeObject(sql);
            return nebulaResult;
        }
    
        @GetMapping("/findVertex")
        public Object findJson2() throws IOErrorException {
            String sql = "lookup on team  yield id(vertex) AS id,properties(vertex).persion_num AS persion_num,properties(vertex).team_name AS team_name;";
            NebulaResult<Info> infoNebulaResult = nebulaTemplate.queryObject(sql, Info.class);
            return infoNebulaResult;
        }
    }
    
        
       

    在这里插入图片描述
    在这里插入图片描述

文章来源: blog.csdn.net,作者:小毕超,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/qq_43692950/article/details/124599111

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。