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

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://www.lryc.cn/news/415241.html

相关文章:

  • STL-vector容器
  • python字符串与变量名互相转换,字典,list操作
  • 企业及园区电力能源管理系统方案
  • 5.3 需求分析
  • 【C++】list介绍以及模拟实现(超级详细)
  • 从艺术创作到作物生长,农业AI迎来“GPT“时刻
  • 前端使用 Konva 实现可视化设计器(19)- 连接线 - 直线、折线
  • C#:通用方法总结—第15集
  • LoadRunner12 添加事务并添加检查点
  • python中的文件
  • Powerdesigner连接mysql数据库,逆向工程生成ER图 (保姆级教程:下载->连接->配置)看这一篇就够了
  • 商家转账到零钱分销返佣申请方案及驳回处理办法
  • 荟萃科技:国外问卷调查有没有实时更新的题库?
  • 【课程总结】Day18:Seq2Seq的深入了解
  • C++利用开发人员命令提示工具查看对象模型
  • 白骑士的PyCharm教学高级篇 3.4 服务器部署与配置
  • 数据库管理-第226期 内存至超线程(20240805)
  • Django学习-数据迁移与数据导入导出
  • 【Nuxt】编程式导航和动态路由
  • 14. 计算机网络HTTPS协议(二)
  • 【算法设计题】实现以字符串形式输入的简单表达式求值,第2题(C/C++)
  • Kylin系列-入门
  • 力扣-46.全排列
  • 博物馆展厅AI交互数字人,解锁创新的文化交互体验
  • DS18B20数字温度传感器操作解析
  • 你的财富正在被一个叫做通货膨胀的怪兽给吞噬掉,你却浑然不觉。
  • 医疗设备漏费控制管理系统的必然性及未来发展性
  • 软件设计师笔记-网络基础知识
  • MMC和eMMC的区别
  • 亚马逊爬虫(Amazonbot)IP地址,真实采集数据