IoTDB时序数据库使用

简介

Apache IoTDB 是一款低成本、高性能的物联网原生时序数据库。它可以解决企业组建物联网大数据平台管理时序数据时所遇到的应用场景复杂、数据体量大、采样频率高、数据乱序多、数据处理耗时长、分析需求多样、存储与运维成本高等多种问题。
IoTDB官网

1. 连接数据库

官方提供了多种语言的连接数据库的方式和案例,这里使用的C#语言连接IoTDB

添加NuGet包 Apache.IoTDB

csharp 复制代码
SessionPool sessionPool = new SessionPool("localhost", 6667, 2);
sessionPool.Open(false).Wait(); //此处必须使用wait,否则在close时后端会报错

2. 写数据

csharp 复制代码
List<string> fields = new List<string>() { "temple" };
List<object> values = new List<object>() { 16.5 };
RowRecord row = new RowRecord(DateTime.UtcNow, values, fields);
await sessionPool.InsertRecordAsync("root.test.device", row);

3. 读数据

目前好像只能执行sql的方式,如果官方能增加类似Sqlsugger语法糖就更好了

csharp 复制代码
var result = await sessionPool.ExecuteQueryStatementAsync("select * from root.test.device");
if (result != null)
{

    for (int i = 0; i < result.RowCount; i++)
    {
        var row = result.Next();
        Console.WriteLine($"{row.Measurements[0]}:{row.Values[0]}");
    }
}

4. 关闭数据库连接

关闭连接,也是比较简单

csharp 复制代码
await sessionPool.Close();
相关推荐
小马爱打代码4 小时前
Redis 集群方案详解:主从复制、哨兵、脑裂、分片集群和哈希槽
数据库·redis·哈希算法
海南java第二人6 小时前
ClickHouse 稀疏索引深度解析:为什么 OLAP 数据库不用 B-Tree?
数据库·clickhouse
Litluecat6 小时前
信创迁移:Oracle切换海量数据库,慢sql扫描
数据库·sql·oracle·信创·海量
消失在人海中6 小时前
Oracle的CURRENT REDO丢失,数据丢失风险分析
数据库·oracle
喵了几个咪7 小时前
选择第三方IAM还是自建权限体系?中小型后台系统权限架构决策指南
数据库·oracle·架构
Elastic 中国社区官方博客8 小时前
Kibana:使用 AI Chat 及 MCP 轻松创建 AI 原生仪表板
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·信息可视化
杨云龙UP8 小时前
Oracle Health Check巡检脚本使用SOP V2.0:从HTML原始报告→生成Word专业巡检报告→交付客户_2026-06-03
linux·运维·数据库·sql·oracle·报告·巡检
Database_Cool_8 小时前
Hudi 湖仓一体架构:阿里云 AnalyticDB MySQL 原生集成最佳实践
数据库·mysql·阿里云
我是一颗柠檬9 小时前
【Redis】发布订阅与消息队列Day8(2026年)
数据库·redis·后端·缓存