IoTDB 入门教程 实战篇④——C#示例(开源)

文章目录

  • 一、前文
  • 二、新建C#项目
  • 三、NuGet安装
  • 四、示例源码
  • 五、查询数据
  • 六、参考

一、前文

IoTDB入门教程——导读

本文详细阐述了如何通过一个C#项目成功连接到IoTDB时序数据库,进而展示了如何向该数据库高效地写入数据以及执行精确的数据查询操作。

此示例旨在为读者提供一个清晰、实用的指导,以便他们在自己的项目中实现与IoTDB的交互。

此示例开源地址:小康师兄/IoTDB示例

二、新建C#项目

  • 创建新项目Windows窗体应用(.Net Framework)
    在这里插入图片描述
    在这里插入图片描述
  • 运行
    在这里插入图片描述

三、NuGet安装

  • 工具—>NuGet 包管理器—>管理解决方案的 NuGet 程序包
    在这里插入图片描述
  • 搜索IoTDB,并安装
    在这里插入图片描述

四、示例源码

此示例开源地址:小康师兄/IoTDB示例

https://gitee.com/weijian.kang/IoTDB-Example/tree/master/Csharp-Example

  • UI布局:两个Button和一个ListView
    在这里插入图片描述

  • 初始化与连接

private async void Form1_Load(object sender, EventArgs e)
{// listView初始化this.listView1.Columns.Clear();this.listView1.Columns.Add("时间", 130);this.listView1.Columns.Add("状态", 60);// 初始化sessionsessionPool = new SessionPool("47.122.63.169", 6667, 2);// 开启sessionawait sessionPool.Open(false);
}private void Form1_FormClosing(object sender, FormClosingEventArgs e)
{// 关闭连接sessionPool.Close();
}
  • 写入数据
private async void insertBtn_Click(object sender, EventArgs e)
{var measures = new List<string> { "status" };var values = new List<object> { 123 };var rowRecord = new RowRecord(DateTime.Now, values, measures);var result = await sessionPool.InsertRecordAsync("root.test.test", rowRecord);Console.WriteLine("insert result="+result);
}
  • 查询数据
private async void queryBtn_Click(object sender, EventArgs e)
{var result = await sessionPool.ExecuteQueryStatementAsync("select status from root.test.test order by time desc");Console.WriteLine("query done, rowCount="+result.RowCount);result.ShowTableNames();//数据更新,UI暂时挂起,直到EndUpdate绘制控件,可以有效避免闪烁并大大提高加载速度 this.listView1.BeginUpdate();   this.listView1.Items.Clear();List<ListViewItem> items = new List<ListViewItem>();for (int i=0; i< result.RowCount; i++){RowRecord rowRecord = result.Next();string[] rows = new string[2];rows[0] = DateTimeOffset.FromUnixTimeMilliseconds(rowRecord.Timestamps).LocalDateTime.ToString("yyyy-MM-dd HH:mm:ss");rows[1] = rowRecord.Values[0].ToString();items.Add(new ListViewItem(rows));}this.listView1.Items.AddRange(items.ToArray());//结束数据处理,UI界面一次性绘制。this.listView1.EndUpdate();  
}
  • 运行截图
    在这里插入图片描述

五、查询数据

  • 再次查询数据,同步验证一下
IoTDB> select status from root.test.test order by time desc
+-----------------------------+---------------------+
|                         Time|root.test.test.status|
+-----------------------------+---------------------+
|2024-07-30T00:20:37.335+08:00|                123.0|
|2024-07-29T17:44:48.752+08:00|                 88.0|
|2024-07-28T20:12:49.883+08:00|                 88.0|
|2024-07-28T20:11:41.161+08:00|                 88.0|
|2024-07-28T19:57:38.855+08:00|                 88.0|
|2024-07-27T16:44:06.000+08:00|                 66.0|
|2024-07-21T08:34:30.341+08:00|                 33.0|
|2024-07-21T08:34:28.155+08:00|                 22.0|
|2024-07-21T08:34:25.675+08:00|                 11.0|
|2024-07-21T08:34:23.284+08:00|                  3.0|
|2024-07-21T08:34:21.513+08:00|                  2.0|
|2024-07-21T08:34:04.378+08:00|                  1.0|
|1970-01-21T06:21:09.846+08:00|                 55.0|
|1970-01-01T08:00:00.534+08:00|                123.0|
|1970-01-01T08:00:00.001+08:00|                123.0|
+-----------------------------+---------------------+
Total line number = 15
It costs 0.084s

六、参考

C# 原生接口| IoTDB Website

觉得好,就一键三连呗(点赞+收藏+关注)

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

Redis高可用之持久化,以及reids的性能管理

一、redis高可用&#xff1a; 在集群当中有一个非常重要的指标&#xff0c;提供正常服务的时间的百分比&#xff08;365天&#xff09;99.9% redis的高可用含义更加宽泛&#xff0c;正常服务是指标之一&#xff0c;数据容量的扩展&#xff0c;数据的安全性 在redis中实现高可…

多模态大模型(MM-LLMs)近期概述

《MM-LLMs: Recent Advances in MultiModal Large Language Models》 论文地址&#xff1a;https://arxiv.org/abs/2401.13601 GitHub地址&#xff1a;https://mm-llms.github.io/ 1.介绍 目的&#xff1a;MM-LLMs旨在减少计算费用并提高多模态预训练的效率, 因为从头开始训…

Data Augmentation数据增强

目录 数据增强是什么 为什么数据增强 数组增强分类 有监督数据增强 无监督数据增强 数据增强是什么 数据增强又称数据扩增&#xff0c;是一种通过应用合理且随机的变换&#xff08;例如图像位移、旋转&#xff09;来增加训练集多样性的技术。让有限的数据产生等价于更多数…

Jenkins集成JDK、git、gitee、maven逐步实现自动拉取,自动部署,自动启动

1. jenkins集成JDK 成功登录Jenkins后&#xff0c;选择Manage Jenkins&#xff0c;选择Tools 集成JDK 2. jenkins集成git 因为Jenkins自动从git远程仓库拉取代码 首先要在Jenkins所在的linux服务器上安装git yum install -y git然后&#xff0c;实行集成JDK的第一步 配置g…

C#:枚举及位标志周边知识详解(小白入门)

文章目录 枚举为什么要有枚举?枚举的性质设置默认类型和显式设置成员的值 位标志(重要)位标记是什么及作用位标志周边知识HasFlag判断是否有该功能枚举前面加Flags的好处 关于枚举的更多知识using static简化代码获取枚举成员的字面量 枚举 为什么要有枚举? 为了增加代码的…

FlowUs息流作为一款技术驱动的笔记和知识管理平台,其核心功能和技术优势为新媒体行业带来了革命性的工作效率提升

FlowUs息流作为一款技术驱动的笔记和知识管理平台&#xff0c;其核心功能和技术优势为新媒体行业带来了革命性的工作效率提升。以下是对其技术特色的深入解析&#xff1a; 本地化技术优化&#xff1a;FlowUs息流通过深入研究中文用户的操作习惯&#xff0c;实现了界面的本地化设…

【WRF安装第二期(Ubuntu)】搭建WRF编译所需系统-系统环境检验

WRF安装第二期&#xff1a;搭建WRF编译所需系统-系统环境检验 0 升级和安装基础环境1 系统环境检验&#xff08;System Environment Tests&#xff09;1.1 检验和安装基础包1.1.1 安装指令1.1.2 检验指令 1.2 WRF安装的目录结构1.2.1 WRF系统环境测试 1.3 测试编译器&#xff0…

Python文件加密库之cryptography使用详解

概要 在现代信息社会中,数据的安全性变得越来越重要。为了保护敏感信息,文件加密技术被广泛应用。Python的cryptography库提供了强大的加密功能,可以轻松实现文件加密和解密。本文将详细介绍如何使用cryptography库进行文件加密,包含具体的示例代码。 cryptography库简介 …

模型剪枝综述

目录 1 深度神经网络的稀疏性&#xff1a; 2 剪枝算法分类&#xff1a; 3 具体的剪枝方法包括&#xff1a; 4 剪枝算法流程&#xff1a; 5 几种常见的剪枝算法&#xff1a; 6 结构化剪枝和非结构化剪枝各有其优缺点&#xff1a; 7 剪枝算法对模型精度的影响 8 影响剪枝…

《集成电路应用》是什么级别的期刊?是正规期刊吗?能评职称吗?

​问题解答 问&#xff1a;《集成电路应用》是不是核心期刊&#xff1f; 答&#xff1a;不是&#xff0c;是知网收录的第一批认定学术期刊。 问&#xff1a;《集成电路应用》级别&#xff1f; 答&#xff1a;国家级。主管单位&#xff1a;中国电子信息产业集团有限公司 主…

【错误总结】Ubuntu系统中执行 sudo apt-get update报错

Ubuntu系统中执行 sudo apt-get update报错 命令行描述升级sudo报错并解决错误描述错误解决原因1&#xff1a;系统网络问题 原因2&#xff1a;设置清华源后/etc/apt/sources.list不匹配原因3&#xff1a;ubuntu自带的源/etc/apt/sources.list有问题 apt-get update成功log参考 …

电脑的录屏功能在哪?精准操作,电脑录屏方法大揭秘

电脑的录屏功能已成为数字时代创作和分享的重要工具。然而&#xff0c;对于许多人来说&#xff0c;要找到电脑上的录屏功能可能并不容易。究竟它们隐藏在哪里&#xff1f;如何启用这个功能呢&#xff1f;这些问题可能会让人感到困惑。 本文将带您一起探索电脑上的录屏功能所在…

ip地址会因为位置不同而改变吗

在数字化时代&#xff0c;IP地址作为互联网用户的“数字指纹”&#xff0c;扮演着至关重要的角色。它不仅是设备接入网络的唯一标识&#xff0c;还常常与用户的地理位置紧密相连。然而&#xff0c;随着移动互联网的普及和人们日常活动的多样化&#xff0c;一个有趣的现象逐渐显…

【漏洞复现】泛微E-Cology9 WorkPlanService 前台SQL注入漏洞(XVE-2024-18112)

0x01 产品简介 泛微e-cology是一款由泛微网络科技开发的协同管理平台&#xff0c;支持人力资源、财务、行政等多功能管理和移动办公。 0x02 漏洞概述 该漏洞是由于泛微e-cology未对用户的输入进行有效的过滤&#xff0c;直接将其拼接进了SQL查询语句中&#xff0c;导致系统出…

Kafka的入门及简单使用

文章目录 前言一、Kafka 的基本架构&#xff1f;1. Producer&#xff08;生产者&#xff09;2. Broker&#xff08;代理/服务器&#xff09;3. Consumer&#xff08;消费者&#xff09;4. Consumer Group&#xff08;消费者组&#xff09;5. Topic&#xff08;主题&#xff09;…

openJdk21镜像打包制作

文章目录 一.目的&#xff1a;二.dockerfile 代码三.调试四.效果图五.声明 一.目的&#xff1a; 制作基于openjdk21的基础镜像&#xff0c;方便后续使用 内容&#xff1a; 1.使用的是Debian 11 slim 作为基础镜像&#xff08;在此感谢no name大佬提醒我alpine做为基础镜像不稳…

TypeScript 与 JavaScript 的对比区别

还是大剑师兰特&#xff1a;曾是美国某知名大学计算机专业研究生&#xff0c;现为航空航海领域高级前端工程师&#xff1b;CSDN知名博主&#xff0c;GIS领域优质创作者&#xff0c;深耕openlayers、leaflet、mapbox、cesium&#xff0c;canvas&#xff0c;webgl&#xff0c;ech…

保研408真题练习:2009年全国硕士研究生入学统一考试(单选篇1)

&#x1f9ca;&#x1f9ca;&#x1f9ca;单项选择题&#xff08;共40道&#xff09; &#x1f9ca;数据结构&#xff08;10道&#xff09; &#x1f965;1.打印机的缓冲区逻辑结构 栈&#xff1a;先进后出&#xff1b; 队列&#xff1a;先进先出。 缓冲区的作用是解决主机…

EasyExcel 初使用—— Java 实现多种写入 Excel 功能

前言 大家好&#xff0c;我是雪荷。之前有一篇博客&#xff08;EasyExcel 初使用—— Java 实现读取 Excel 功能_java easyexcel.read-CSDN博客&#xff09;介绍了 Java 如何读取 Excel 表格&#xff0c;那么此篇博客就和大家介绍下 Java 如何利用 EasyExcel 写入 Excel。 Ea…

基于PHP+MySQL组合开发的微信活动投票小程序源码系统 带完整的安装代码包以及搭建部署教程

系统概述 在当今数字化时代&#xff0c;微信作为社交媒体的巨头&#xff0c;为企业和个人提供了丰富的互动营销平台。其中&#xff0c;投票活动作为一种有效的用户参与和互动方式&#xff0c;被广泛应用于各种场景。为了满足这一需求&#xff0c;我们推出了一款基于PHPMySQL组…