Java读取InfluxDB数据库的方法

  本文介绍基于Java语言,读取InfluxDB数据库的方法,包括读取InfluxDB的所有数据库,以及指定数据库中的measurementfieldtag等。

  首先,创建一个Java项目,用于撰写代码。如果大家是基于IDEA来创建项目,则可以参考文章IDEA新建项目并撰写Java代码的方法(https://blog.csdn.net/zhebushibiaoshifu/article/details/140302869)中提到的方法。

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

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

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

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

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

  接下来,即可开始撰写代码。这里的这个代码仅仅是一个非常简单的示例,只是我当初学习用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 Query("SHOW MEASUREMENTS 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 keysprivate 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: innerList) {System.out.println(object);}}System.out.println();}// Show tag valuesprivate static void showTagValues(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 keysprivate 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 dataprivate 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,所以是直接打印的;在实际应用中,大家可以修改一下代码,更优雅地格式化输出。

  至此,大功告成。

欢迎关注:疯狂学习GIS

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/890994.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

嵌入式驱动开发详解7(并发、竞争、中断)

文章目录 前言并发和竞争原子操作自旋锁信号量互斥体 中断中断简介中断API上半部和下半部设备树分析中断号获取源码 后续参考文献 前言 中断会引起线程的切换&#xff0c;并发和竞争也是对线程切换的一种灵活保护和处理&#xff0c;因此这里将中断和并发与竞争放在一块讲解说明…

渗透测试常用术语总结

一、攻击篇 1&#xff0e;攻击工具 肉鸡 所谓“肉鸡”是一种很形象的比喻&#xff0c;比喻那些可以被攻击者控制的电脑、手机、服务器或者其他摄像头、路由器等智能设备&#xff0c;用于发动网络攻击。 例如在2016年美国东海岸断网事件中&#xff0c;黑客组织控制了大…

11.MySQL视图特性

目录 视图基本使用视图规则和限制 视图 视图是一个虚拟表, 其内容有查询定义. 同真实的表一样, 视图包含一系列带有名称的列和行数据. 视图的数据变化会影响到基表, 基表的数据变化也会影响到视图, 这个视图和刚刚讲的ReadView之间没有任何关系. 基本使用 创建视图: create vi…

【RabbitMQ高级篇】消息可靠性问题(1)

目录 1.消息可靠性 1.1.生产者消息确认 1.1.1.修改配置 1.1.2.定义Return回调 1.1.3.定义ConfirmCallback 1.2.消息持久化 1.2.1.交换机持久化 1.2.2.队列持久化 1.2.3.消息持久化 1.3.消费者消息确认 1.3.1.演示none模式 1.3.2.演示auto模式 1.4.消费失败重试机制…

strrchr的概念和使用案例

strrchr 是 C 语言标准库中的一个函数&#xff0c;用于在字符串中查找最后一次出现的字符&#xff0c;并返回指向该字符的指针。 概念&#xff1a; strrchr 函数在给定的字符串中从末尾开始搜索指定的字符&#xff0c;返回一个指向该字符最后一次出现的指针。如果字符在字符串…

4-1 输出一组成绩中的最高分和最低分

第一行输入人数n&#xff0c;第二行输入每个人的成绩&#xff0c;用空格分开。输出所有成绩中的最高分和最低分。 输入格式: 第一行输入n&#xff0c;大于0的整数&#xff1b;第二行输入n个大于等于0&#xff0c;小于等于100的整数&#xff0c;用空格分开。 输出格式: 最高…

前端Python应用指南(六)构建RESTful API:使用Flask和Django实现用户认证与授权

《写给前端的python应用指南》系列&#xff1a; &#xff08;一&#xff09;快速构建 Web 服务器 - Flask vs Node.js 对比&#xff08;二&#xff09;深入Flask&#xff1a;理解Flask的应用结构与模块化设计&#xff08;三&#xff09;Django vs Flask&#xff1a;哪种框架适…

《Vue3 四》Vue 的组件化

组件化&#xff1a;将一个页面拆分成一个个小的功能模块&#xff0c;每个功能模块完成自己部分的独立的功能。任何应用都可以被抽象成一棵组件树。 Vue 中的根组件&#xff1a; Vue.createApp() 中传入对象的本质上就是一个组件&#xff0c;称之为根组件&#xff08;APP 组件…

ASO优化之增加应用程序评论行之有效的成功战略

应用评论不仅对于用户信任至关重要&#xff0c;而且对于提高应用可见度、转化率以及整体应用商店优化&#xff08;ASO&#xff09;也至关重要。评论和评分会影响App Store和Google Play平台上算法的排名,这些平台优先考虑具有更高参与度和满意度指标的应用程序。下面,我们将概述…

字符串存储、分割相关总结(strncpy 函数和strtok() 函数相关)

1.想用这些函数都需要导入头文件 #include<string.h> 2.怎么创建字符串并输入 #define maxsize 100 char a[maxsize1];//创建字符串&#xff0c;预留一个位置放\0 【1】scanf("%s",a);//使用 scanf 函数读取不带空格的字符串 【2】fgets(a, sizeof(a), stdi…

【Rust自学】7.4. use关键字 Pt.2 :重导入与换国内镜像源教程

喜欢的话别忘了点赞、收藏加关注哦&#xff0c;对接下来的教程有兴趣的可以关注专栏。谢谢喵&#xff01;(&#xff65;ω&#xff65;) 7.4.1. 使用pub use重新导入名称 使用use将路径导入作用域内后。该名称在词作用域内是私有的。 以上一篇文章的代码为例&#xff1a; m…

快速排序学习优化

首先&#xff0c;上图。 ‘’’ cpp int partSort(int *a ,int left,int right) {int keyi left; //做左侧基准while(left<right){while(left<right && a[right]>a[keyi]){right--;}while(left<right && a[left]<a[keyi]){left;}swap(a[left…

宏集eX710物联网工控屏在石油开采机械中的应用与优势

案例概况 客户&#xff1a;天津某石油机械公司 应用产品&#xff1a;宏集eX710物联网工控屏 应用场景&#xff1a;钻井平台设备控制系统 一、应用背景 石油开采和生产过程复杂&#xff0c;涵盖钻井平台、采油设备、压缩机、分离器、管道输送系统等多种机械设备。这些设备通…

【MySQL】第一弹----库的操作及数据类型

笔上得来终觉浅,绝知此事要躬行 &#x1f525; 个人主页&#xff1a;星云爱编程 &#x1f525; 所属专栏&#xff1a;MySQL &#x1f337;追光的人&#xff0c;终会万丈光芒 &#x1f389;欢迎大家点赞&#x1f44d;评论&#x1f4dd;收藏⭐文章 一、SQL 语句分类 DDL:数据定…

【Ubuntu】如何轻松在Apache服务器上部署Laravel博客系统

Laravel 是一个 PHP 框架&#xff0c;和 Angular 以及 Symfony 类似&#xff0c;它能让你快速且高效地搭建出功能强大的网站。在这篇文章里&#xff0c;我将手把手教你如何在 Ubuntu 系统上使用 Apache 和 MySQL 部署 Laravel 应用。 步骤 1&#xff1a;更新系统 首先&#x…

阿里云-将旧服务器数据与配置完全迁移至新服务器

文章目录 一&#xff1a;创建镜像二&#xff1a;将创建好的镜像复制到新服务器所在的目标地域&#xff08;如果新服务器与镜像在同一地域就不用进行这一操作&#xff09;三&#xff1a;将镜像配置到新服务器上四&#xff1a;导出安全组&#xff08;如果新服务器与旧服务器使用同…

MYSQL无法被连接问题

如果您在尝试连接到MySQL服务器时遇到问题&#xff0c;以下描述了您可以采取的一些措施来纠正该问题。 确保服务器正在运行。如果没有&#xff0c;则客户端无法连接到它。例如&#xff0c;如果尝试连接到服务器失败并出现以下消息之一&#xff0c;则可能是服务器未运行&#xf…

vue3使用element-plus,解决 el-table 多选框,选中后翻页再回来选中失效问题

问题&#xff1a;勾选的数据分页再回来回消失 1.在el-table中加 :row-key"getRowKey" const getRowKey (row) > { return row.id; // id必须是唯一的 }; 2.给type为selection的el-table-column添加上reserve-selection属性 <el-tableref"multipleTab…

防火墙原理介绍大全

硬件防火墙的原理 软件防火墙只有包过滤的功能&#xff0c;硬件防火墙中可能还有除软件防火墙以外的其他功能&#xff0c;例如CF&#xff08;内容过滤&#xff09;IDS&#xff08;入侵侦测&#xff09;IPS&#xff08;入侵防护&#xff09;以及VPN等等的功能。 也就是说硬件防…

StableAnimator模型的部署:复旦微软提出可实现高质量和高保真的ID一致性人类视频生成

文章目录 一、项目介绍二、项目部署模型的权重下载提取目标图像的关节点图像&#xff08;这个可以先不看先用官方提供的数据集进行生成&#xff09;提取人脸&#xff08;这个也可以先不看&#xff09;进行图片的生成 三、模型部署报错 一、项目介绍 由复旦、微软、虎牙、CMU的…