Java读取InfluxDB数据库的方法详解

2025-01-14 04:50

本文主要是介绍Java读取InfluxDB数据库的方法详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Java读取InfluxDB数据库的方法详解》本文介绍基于Java语言,读取InfluxDB数据库的方法,包括读取InfluxDB的所有数据库,以及指定数据库中的measurement、field、...

首先,创建一个Java项目,用于撰写代码。

接下来,配置所需要的依赖;这里我们就选择可用于与InfluxDB数据库进行交互的、官方支持的Java客户端库influxdb-java。因为我是基于Maven来配置依赖的,所以就在项目的pom.XML文件中China编程,添加如下的内容。

<dependencies>
    <dependency>
        <groupId>org.influxdb</groupId>
        <artifactId>influxdb-java</artifactId>
        <version>2.8</version>
    </dependency>
</dependencies>

添加上述代码后,如下图所示。

Java读取InfluxDB数据库的方法详解

刚刚增添完毕上述代码时,pom.xml文件中influxdb-java依赖会飘红,我们就刷新一下Maven,让他下载对应的依赖;如下图所示。

Java读取InfluxDB数据库的方法详解

随后,可以在Dependencies中看到已经配置好了所需的influxdb-java依赖,如下图所示。

Java读取InfluxDB数据库的方法详解

接下来,即可开始撰写代码。这里的这个代码仅仅是一个非常简单的示例,只是我当初学习用Java语言读取InfluxDB数据库用的;大家可以在这个基础上,按照自己的需求进一步丰富代码逻辑。完整代码如下所示。

import org.influxdb.InfluxDB;
import org.influxdb.InfluxDBFactory;
import org.influxdb.dto.Query;
import org.influxdb.dto.QueryResult;
import org.jetbrains.annotations.NotNull;

import java.util.List;
import java.util.Scanner;

public class Main {
    private static final String url = "http://127.0.0.1:8086";
    private static final String username = "root";
    private static final String password = "";

    public static void main(String[] args) {
        InfluxDB influxDB = InfluxDBFactory.connect(url, username, password);
        showDatabases(influxDB);
        showMeasurements(influxDB);
        showData(influxDB);
    }

    // Show database(s)
    private static void showDatabases(InfluxDB influxDB) {
        QueryResult queryResult = influxDB.query(new Query("SHOW DATABASES"));
        QueryResult.Series series = queryResult.getResults().get(0).getSeries().get(0);
        List<List<Object>> databaseList = series.getValues();
        System.out.println("Database(s) is(are):");
        for (List<Object> innerList: databaseList) {
            for (Object object: innerList) {
                System.out.println(object);
            }
        }
        System.out.println();
    }

    // Show measurement(s)
    private static void showMeasurements(InfluxDB influxDB) {
        Scanner scanner = new Scanner(System.in);
        System.out.print("Please enter the database name: ");
        String databaseName = scanner.nextLine();

        try {
            List<List<Object>> measurementsList = influxDB.query(new Quephpry("SHOW MEASUREMENTS 编程China编程ON " + databaseName)).getResults().get(0).getSeries().get(0).getValues();
            System.out.println("Measurement(s) for " + databaseName + " is(are):");
            for (List<Object> innerList: measurementsList) {
                for (Object object: innerList) {
                    System.out.println(object);
                }
            }
            System.out.println();
            showTagKeys(influxDB, databaseName);
            showTagValues(influxDB, databaseName);
            showFieldKeys(influxDB, databaseName);
        } catch (Exception e) {
            System.out.println("Measurement(s) for " + databaseName + " is empty!");
            return;
        }
    }

    // Show tag keys
    private static void showTagKeys(InfluxDB influxDB, String databaseName) {
        List<List<Object>> tagKeysList = influxDB.query(new Query("SHOW TAG KEYS ON " + databaseName)).getResults().get(0).getSeries().get(0).getValues();
        System.out.println("Tag Key(s) for " + databaseName + " is(are):");
        for (List<Object> innerList: tagKeysList) {
            for (Object object: innerLChina编程ist) {
                System.out.println(object);
            }
        }
        System.out.println();
    }

    // Show tag values
    private static void showTaphpgValues(InfluxDB influxDB, String databaseName) {
        Scanner scanner = new Scanner(System.in);
        System.out.print("Please enter the tag key name: ");
        String TagKey = scanner.nextLine();

        List<List<Object>> tagValuesList = influxDB.query(new Query("SHOW TAG VALUES ON " + databaseName + " WITH KEY = " + TagKey)).getResults().get(0).getSeries().get(0).getValues();
        System.out.println("Tag Value(s) is(are):");
        for (List<Object> innerList: tagValuesList) {
            System.out.println(innerList.get(0) + ": " + innerList.get(1));
        }
        System.out.println();
    }

    // Show field keys
    private static void showFieldKeys(InfluxDB influxDB, String databaseName) {
        List<List<Object>> fieldKeysList = influxDB.query(new Query("SHOW FIELD KEYS ON " + databaseName)).getResults().get(0).getSeries().get(0).getValues();
        System.out.println("Field Key(s) and Type(s) are:");
        for (List<Object> innerList: fieldKeysList) {
            System.out.println(innerList.get(0) + ": " + innerList.get(1));
        }
        System.out.println();
    }

    // Show data
    private static void showData(@NotNull InfluxDB influxDB) {
        Scanner scanner = new Scanner(System.in);
        System.out.print("Please enter the database name: ");
        String databaseName = scanner.nextLine();

        System.out.print("Please enter the measurements name: ");
        String measurementName = scanner.nextLine();

        influxDB.setDatabase(databaseName);
        QueryResult dataResult = influxDB.query(new Query("SELECT * FROM " + measurementName));
        System.out.println(dataResult);
    }
}

代码整体思路也很简单,这里再简单介绍一下代码的流程。

首先,需要连接到InfluxDB数据库。在这一部分,通过InfluxDBFactory.connect创建了一个本地运行的InfluxDB实例的连接,使用默认的URL (也就是http://127.0.0.1:8086),并配置用户名和密码。

随后,showDatabases方法执行了SHOW DATABASES,用以查询并打印出InfluxDB实例所有数据库的名字。从这一部分的代码开始,后续所有代码在操作数据库方面的逻辑都是很类似的——通过模拟并执行InfluxDB的数据库语句,来实现各项操作。

接下来,showMeasurements方法可以让我们输入一个数据库名,然后执行SHOW MEASUREMENTS查询来获取该数据库中所有measurement的名称,并打印出来。如果measurement为空,则会输出相应的提示信息。

其次,showTagKeys方法用于列出指定数据库的所有tag key,其后的showTagValues方法则可以让我们输入一个tag key名,随后查询并打印出该tag key对应的所有tag value。

紧接着,showFieldKeys方法用于列出指定数据库中所有的field key。

最后,showData方法让我们输入一个数据库和measurement的名称,随后查询、获取该measurement下的所有数据,并将结果直接打印出来。当然,我这里当初只是为了验证是否读取到了measurement,所以是直接打印的;在实际应用中,大家可以修改一下代码,更优雅地格式化输出。

至此,大功告成。

以上就是Java读取InfluxDB数据库的方法详解的详细内容,更多关于Java读取InfluxDB的资料请关注China编程(www.chinasem.cn)其它相关文章!

这篇关于Java读取InfluxDB数据库的方法详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153053

相关文章

Java捕获ThreadPoolExecutor内部线程异常的四种方法

《Java捕获ThreadPoolExecutor内部线程异常的四种方法》这篇文章主要为大家详细介绍了Java捕获ThreadPoolExecutor内部线程异常的四种方法,文中的示例代码讲解详细,感... 目录方案 1方案 2方案 3方案 4结论方案 1使用 execute + try-catch 记录

Jmeter如何向数据库批量插入数据

《Jmeter如何向数据库批量插入数据》:本文主要介绍Jmeter如何向数据库批量插入数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Jmeter向数据库批量插入数据Jmeter向mysql数据库中插入数据的入门操作接下来做一下各个元件的配置总结Jmete

SpringBoot接收JSON类型的参数方式

《SpringBoot接收JSON类型的参数方式》:本文主要介绍SpringBoot接收JSON类型的参数方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、jsON二、代码准备三、Apifox操作总结一、JSON在学习前端技术时,我们有讲到过JSON,而在

MySql中的数据库连接池详解

《MySql中的数据库连接池详解》:本文主要介绍MySql中的数据库连接池方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql数据库连接池1、概念2、为什么会出现数据库连接池3、原理4、数据库连接池的提供商5、DataSource数据源6、DBCP7、C

Spring-AOP-ProceedingJoinPoint的使用详解

《Spring-AOP-ProceedingJoinPoint的使用详解》:本文主要介绍Spring-AOP-ProceedingJoinPoint的使用方式,具有很好的参考价值,希望对大家有所帮... 目录ProceedingJoinPoijsnt简介获取环绕通知方法的相关信息1.proceed()2.g

Python中Windows和macOS文件路径格式不一致的解决方法

《Python中Windows和macOS文件路径格式不一致的解决方法》在Python中,Windows和macOS的文件路径字符串格式不一致主要体现在路径分隔符上,这种差异可能导致跨平台代码在处理文... 目录方法 1:使用 os.path 模块方法 2:使用 pathlib 模块(推荐)方法 3:统一使

Spring Security注解方式权限控制过程

《SpringSecurity注解方式权限控制过程》:本文主要介绍SpringSecurity注解方式权限控制过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、摘要二、实现步骤2.1 在配置类中添加权限注解的支持2.2 创建Controller类2.3 Us

Spring MVC跨域问题及解决

《SpringMVC跨域问题及解决》:本文主要介绍SpringMVC跨域问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录跨域问题不同的域同源策略解决方法1.CORS2.jsONP3.局部解决方案4.全局解决方法总结跨域问题不同的域协议、域名、端口

SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法

《SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法》本文主要介绍了SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录方法1:更改IDE配置方法2:在Eclipse中清理项目方法3:使用Maven命令行在开发Sprin

JAVA SE包装类和泛型详细介绍及说明方法

《JAVASE包装类和泛型详细介绍及说明方法》:本文主要介绍JAVASE包装类和泛型的相关资料,包括基本数据类型与包装类的对应关系,以及装箱和拆箱的概念,并重点讲解了自动装箱和自动拆箱的机制,文... 目录1. 包装类1.1 基本数据类型和对应的包装类1.2 装箱和拆箱1.3 自动装箱和自动拆箱2. 泛型2