TDengine.C/C++ 连接器
简介
C/C++ 开发人员可以使用 TDengine 的客户端驱动,即 C/C++ 连接器(以下都用 TDengine 客户端驱动表示),开发自己的应用来连接 TDengine 集群完成数据存储、查询以及其他功能。TDengine 客户端驱动的 API 类似于 MySQL 的 C API。应用程序使用时,需要包含 TDengine 头文件,里面列出了提供的 API 的函数原型;应用程序还要链接到所在平台上对应的动态库。
TDengine 的客户端驱动提供了 taosws 和 taos 两个动态库,分别支持 WebSocket 连接和原生连接。WebSocket 连接和原生连接的区别是 WebSocket 连接方式不要求客户端和服务端版本完全匹配,而原生连接要求,在性能上 WebSocket 连接方式也接近于原生连接,一般我们推荐使用 WebSocket 连接方式。
下面我们分开介绍两种连接方式的使用方法。
WebSocket 连接方式
WebSocket 连接方式需要使用 taosws.h 头文件和 taosws 动态库。
#include <taosws.h>
TDengine 服务端或客户端安装后,taosws.h
位于:
- Linux:
/usr/local/taos/include
- Windows:
C:\TDengine\include
- macOS:
/usr/local/include
TDengine 客户端驱动的动态库位于:
- Linux:
/usr/local/taos/driver/libtaosws.so
- Windows:
C:\TDengine\driver\taosws.dll
- macOS:
/usr/local/lib/libtaosws.dylib
支持的平台
请参考 支持的平台列表
版本历史
TDengine 客户端版本 | 主要变化 | TDengine 版本 |
---|---|---|
3.3.3.0 | 首次发布,提供了 SQL 执行,参数绑定,无模式写入和数据订阅等全面功能支持。 | 3.3.2.0 及更高版本 |
错误码
在 C 接口的设计中,错误码采用整数类型表示,每个错误码都对应一个特定的错误状态。如未特别说明,当 API 的返回值是整数时,0 代表成功,其它是代表失败原因的错误码,当返回值是指针时,NULL 表示失败。
WebSocket 连接方式单独的错误码在 taosws.h
中,
错误码 | 错误描述 | 可能的出错场景或者可能的原因 | 建议用户采取的措施 |
---|---|---|---|
0xE000 | DSN 错误 | DSN 不符合规范 | 检查 dsn 字符串是否符合规范 |
0xE001 | 内部错误 | 不确定 | 保留现场和日志,github 上报 issue |
0xE002 | 连接关闭 | 网络断开 | 请检查网络状况,查看 taosadapter 日志。 |
0xE003 | 发送超时 | 网络断开 | 请检查网络状况 |
0xE004 | 接收超时 | 慢查询,或者网络断开 | 排查 taosadapter 日志 |
其余错误码请参考同目录下 taoserror.h
文件,详细的原生连接错误码说明参考:错误码。
:::info
WebSocket 连接方式错误码只保留了原生连接错误码的后两个字节。
:::
示例程序
本节展示了使用客户端驱动访问 TDengine 集群的常见访问方式的示例代码。
-
同步查询示例:同步查询
-
参数绑定示例:参数绑定
-
无模式写入示例:无模式写入
-
订阅和消费示例:订阅和消费
:::info
更多示例代码及下载请见 GitHub。
:::
API 参考
以下分别介绍 TDengine 客户端驱动的 DSN、基础 API、同步查询 API、参数绑定 API、无模式写入 API 和 数据订阅订阅 API。
DSN
C/C++ WebSocket 连接器通过 DSN 连接描述字符串来表示连接信息。
DSN 描述字符串基本结构如下:
<driver>[+<protocol>]://[[<username>:<password>@]<host>:<port>][/<database>][?<p1>=<v1>[&<p2>=<v2>]]
|------|------------|---|-----------|-----------|------|------|------------|-----------------------|
|driver| protocol | | username | password | host | port | database | params |
各部分意义见下表:
-
driver:必须指定驱动名以便连接器选择何种方式创建连接,支持如下驱动名:
- taos:默认驱动,支持 SQL 执行,参数绑定,无模式写入。
- tmq:使用 TMQ 订阅数据。
-
protocol:显示指定以何种方式建立连接,例如:
taos+ws://localhost:6041
指定以 WebSocket 方式建立连接。- http/ws:使用 WebSocket 协议。
- https/wss:在 WebSocket 连接方式下显示启用 SSL/TLS 协议。
-
username/password:用于创建连接的用户名及密码。
-
host/port:指定创建连接的服务器及端口,当不指定服务器地址及端口时 WebSocket 连接默认为
localhost:6041
。 -
database:指定默认连接的数据库名,可选参数。
-
params:其他可选参数。
一个完整的 DSN 描述字符串示例如下:taos+ws://localhost:6041/test
,表示使用 WebSocket(ws
)方式通过 6041
端口连接服务器 localhost
,并指定默认数据库为 test
。
基础 API
基础 API 用于完成创建数据库连接等工作,为其它 API 的执行提供运行时环境。
-
char *ws_get_client_info()
- 接口说明:获取客户端版本信息。
- 返回值:返回客户端版本信息。
-
WS_TAOS *ws_connect(const char *dsn)
- 接口说明:创建数据库连接,初始化连接上下文。
- 参数说明:
- dsn:[入参] 连接信息,见上文 DSN 章节。
- 返回值:返回数据库连接,返回值为空表示失败。应用程序需要保存返回的参数,以便后续使用。
:::info
同一进程可以根据不同的 dsn 连接多个 TDengine 集群
:::
-
const char *ws_get_server_info(WS_TAOS *taos)
- 接口说明:获取服务端版本信息。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
ws_connect()
函数建立。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回获取服务端版本信息。
-
int32_t ws_select_db(WS_TAOS *taos, const char *db)
- 接口说明:将当前的缺省数据库设置为
db
。 - 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
ws_connect()
函数建立。 - db:[入参] 数据库名称。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:
0
:成功,非0
:失败,详情请参考错误码页面。
- 接口说明:将当前的缺省数据库设置为
-
int32_t ws_get_current_db(WS_TAOS *taos, char *database, int len, int *required)
- 接口说明:获取当前数据库名称。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
ws_connect()
函数建立。 - database:[出参] 存储当前数据库名称。
- len:[入参] database 的空间大小。
- required:[出参] 存储当前数据库名称所需的空间(包含最后的’\0’)。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:
0
:成功,-1
:失败,可调用函数 ws_errstr(NULL) 获取更详细的错误信息。- 如果,database == NULL 或者 len<=0 返回失败。
- 如果,len 小于 存储数据库名称所需的空间(包含最后的’\0’),返回失败,database 里赋值截断的数据,以’\0’结尾。
- 如果,len 大于等于 存储数据库名称所需的空间(包含最后的’\0’),返回成功,database 里赋值以’\0‘结尾数据库名称。
-
int32_t ws_close(WS_TAOS *taos);
- 接口说明:关闭连接。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
ws_connect()
函数建立。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:
0
:成功,非0
:失败,详情请参考错误码页面。
同步查询
本小节介绍 API 均属于同步接口。应用调用后,会阻塞等待响应,直到获得返回结果或错误信息。
-
WS_RES *ws_query(WS_TAOS *taos, const char *sql)
- 接口说明:执行 SQL 语句,可以是 DQL、DML 或 DDL 语句。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
ws_connect()
函数建立。 - sql:[入参] 需要执行 SQL 语句。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:不能通过返回值是否是
NULL
来判断执行结果是否失败,而是需要调用ws_errno()
函数解析结果集中的错误代码来进行判断。- ws_errno 返回值:
0
:成功,-1
:失败,详情请调用 ws_errstr 函数来获取错误提示。
- ws_errno 返回值:
-
int32_t ws_result_precision(const WS_RES *rs)
- 接口说明:返回结果集时间戳字段的精度类别。
- 参数说明:
- res:[入参] 结果集。
- 返回值:
0
:毫秒,1
:微秒,2
:纳秒。
-
WS_ROW ws_fetch_row(WS_RES *rs)
- 接口说明:按行获取查询结果集中的数据。
- 参数说明:
- res:[入参] 结果集。
- 返回值:非
NULL
:成功,NULL
:失败,可调用函数 ws_errstr(NULL) 获取更详细的错误信息。
-
int32_t ws_fetch_raw_block(WS_RES *rs, const void **pData, int32_t *numOfRows)
- 接口说明:批量获取查询结果集中的数据。
- 参数说明:
- res:[入参] 结果集。
- pData:[出参] 用于存储从结果集中获取一个数据块。
- numOfRows:[出参] 用于存储从结果集中获取数据块包含的行数。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
-
int32_t ws_num_fields(const WS_RES *rs)
和int32_t ws_field_count(const WS_RES *rs)
- 接口说明:这两个 API 等价,用于获取查询结果集中的列数。
- 参数说明:
- res:[入参] 结果集。
- 返回值:返回值为结果集中列的数量。
-
int32_t ws_affected_rows(const WS_RES *rs)
- 接口说明:获取被所执行的 SQL 语句影响的行数。
- 参数说明:
- res:[入参] 结果集。
- 返回值:返回值表示受影响的行数。
-
int64_t ws_affected_rows64(const WS_RES *rs)
- 接口说明:获取被所执行的 SQL 语句影响的行数。
- 参数说明:
- res:[入参] 结果集。
- 返回值:返回值表示受影响的行数。
-
const struct WS_FIELD *ws_fetch_fields(WS_RES *rs)
- 接口说明:获取查询结果集每列数据的属性(列的名称、列的数据类型、列的长度),与
ws_num_fields()
配合使用,可用来解析ws_fetch_row()
返回的一个元组 (一行) 的数据。 - 参数说明:
- res:[入参] 结果集。
- 返回值:非
NULL
:成功,返回一个指向 WS_FIELD 结构体的指针,每个元素代表一列的元数据。NULL
:失败。
- 接口说明:获取查询结果集每列数据的属性(列的名称、列的数据类型、列的长度),与
-
int32_t ws_stop_query(WS_RES *rs)
- 接口说明:停止当前查询的执行。
- 参数说明:
- res:[入参] 结果集。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
-
int32_t ws_free_result(WS_RES *rs)
- 接口说明:释放查询结果集以及相关的资源。查询完成后,务必调用该 API 释放资源,否则可能导致应用内存泄露。但也需注意,释放资源后,如果再调用
ws_fetch_fields()
等获取查询结果的函数,将导致应用崩溃。 - 参数说明:
- res:[入参] 结果集。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:释放查询结果集以及相关的资源。查询完成后,务必调用该 API 释放资源,否则可能导致应用内存泄露。但也需注意,释放资源后,如果再调用
-
const char *ws_errstr(WS_RES *rs)
- 接口说明:获取最近一次 API 调用失败的原因,返回值为字符串标识的错误提示信息。
- 参数说明:
- res:[入参] 结果集。
- 返回值:字符串标识的错误提示信息。
-
int32_t ws_errno(WS_RES *rs)
- 接口说明:获取最近一次 API 调用失败的原因,返回值为错误代码。
- 参数说明:
- res:[入参] 结果集。
- 返回值:字符串标识的错误提示信息。
:::note
TDengine 推荐数据库应用的每个线程都建立一个独立的连接,或基于线程建立连接池。不要在应用中将该连接 (WS_TAOS*) 结构体传递到不同的线程共享使用。
另一个需要注意的是,在上述同步 API 执行过程中,不能调用类似 pthread_cancel 之类的 API 来强制结束线程,因为涉及一些模块的同步操作,如果强制结束线程有可能造成包括但不限于死锁等异常状况。
:::
参数绑定
除了直接调用 ws_query()
通过执行 SQL 进行数据写入,TDengine 也提供了支持参数绑定的 Prepare API,风格与 MySQL 类似,目前也仅支持用问号 ?
来代表待绑定的参数。
通过参数绑定接口写入数据时,可以避免 SQL 语法解析的资源消耗,从而在绝大多数情况下显著提升写入性能。此时的典型操作步骤如下:
- 调用
ws_stmt_init()
创建参数绑定对象; - 调用
ws_stmt_prepare()
解析 INSERT 语句; - 如果 INSERT 语句中预留了表名但没有预留 TAGS,那么调用
ws_stmt_set_tbname()
来设置表名; - 如果 INSERT 语句中既预留了表名又预留了 TAGS(例如 INSERT 语句采取的是自动建表的方式),那么调用
ws_stmt_set_tbname_tags()
来设置表名和 TAGS 的值; - 调用
ws_stmt_bind_param_batch()
以多行的方式设置 VALUES 的值; - 调用
ws_stmt_add_batch()
把当前绑定的参数加入批处理; - 可以重复第 3 ~ 6 步,为批处理加入更多的数据行;
- 调用
ws_stmt_execute()
执行已经准备好的批处理指令; - 执行完毕,调用
ws_stmt_close()
释放所有资源。
说明:如果 ws_stmt_execute()
执行成功,假如不需要改变 SQL 语句的话,那么是可以复用 ws_stmt_prepare()
的解析结果,直接进行第 3 ~ 6 步绑定新数据的。但如果执行出错,那么并不建议继续在当前的环境上下文下继续工作,而是建议释放资源,然后从 ws_stmt_init()
步骤重新开始。
接口相关的具体函数如下(也可以参考 stmt_insert_demo.c 文件中使用对应函数的方式):
-
WS_STMT *ws_stmt_init(const WS_TAOS *taos)
- 接口说明:初始化一个预编译的 SQL 语句对象。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
ws_connect()
函数建立。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:非
NULL
:成功,返回一个指向 WS_STMT 结构体的指针,该结构体表示预编译的 SQL 语句对象。NULL
:失败,详情请调用 ws_stmt_errstr() 函数来获取错误提示。
-
int ws_stmt_prepare(WS_STMT *stmt, const char *sql, unsigned long len)
- 接口说明:解析一条预编译的 SQL 语句,将解析结果和参数信息绑定到 stmt 上。
- 参数说明:
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- sql:[入参] 需要解析的 SQL 语句。
- len:[入参] 参数 sql 的长度。如果参数 len 大于 0,将使用此参数作为 SQL 语句的长度,如等于 0,将自动判断 SQL 语句的长度。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
-
int ws_stmt_bind_param_batch(WS_STMT *stmt, const WS_MULTI_BIND *bind, uint32_t len)
- 接口说明:以多列的方式传递待绑定的数据,需要保证这里传递的数据列的顺序、列的数量与 SQL 语句中的 VALUES 参数完全一致。
- 参数说明:
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- bind:[入参] 指向一个有效的 WS_MULTI_BIND 结构体指针,该结构体包含了要批量绑定到 SQL 语句中的参数列表。
- len:[入参] bind 数组的元素个数。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
-
int ws_stmt_set_tbname(WS_STMT *stmt, const char *name)
- 接口说明:(仅支持用于替换 INSERT 语句中的参数值)当 SQL 语句中的表名使用了
?
占位时,可以使用此函数绑定一个具体的表名。 - 参数说明:
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- name:[入参] 指向一个包含子表名称的字符串常量。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:(仅支持用于替换 INSERT 语句中的参数值)当 SQL 语句中的表名使用了
-
int ws_stmt_set_tbname_tags(WS_STMT *stmt, const char *name, const WS_MULTI_BIND *bind, uint32_t len);
- 接口说明:(仅支持用于替换 INSERT 语句中的参数值)当 SQL 语句中的表名和 TAGS 都使用了
?
占位时,可以使用此函数绑定具体的表名和具体的 TAGS 取值。最典型的使用场景是使用了自动建表功能的 INSERT 语句(目前版本不支持指定具体的 TAGS 列)。TAGS 参数中的列数量需要与 SQL 语句中要求的 TAGS 数量完全一致。 - 参数说明:
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- name:[入参] 指向一个包含子表名称的字符串常量。
- tags:[入参] 指向一个有效的 WS_MULTI_BIND 结构体指针,该结构体包含了子表标签的值。
- len:[入参] bind 数组的元素个数。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:(仅支持用于替换 INSERT 语句中的参数值)当 SQL 语句中的表名和 TAGS 都使用了
-
int ws_stmt_add_batch(WS_STMT *stmt)
- 接口说明:将当前绑定的参数加入批处理中,调用此函数后,可以再次调用
ws_stmt_bind_param_batch()
绑定新的参数。需要注意,此函数仅支持 INSERT/IMPORT 语句,如果是 SELECT 等其他 SQL 语句,将返回错误。- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:将当前绑定的参数加入批处理中,调用此函数后,可以再次调用
-
int ws_stmt_execute(WS_STMT *stmt, int32_t *affected_rows)
- 接口说明:执行准备好的语句。目前,一条语句只能执行一次。
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- affected_rows:[出参] 成功写入的行数。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:执行准备好的语句。目前,一条语句只能执行一次。
-
int ws_stmt_affected_rows(WS_STMT *stmt)
- 接口说明:获取执行预编译 SQL 语句后受影响的行数。
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:返回受影响的行数。
- 接口说明:获取执行预编译 SQL 语句后受影响的行数。
-
int ws_stmt_affected_rows_once(WS_STMT *stmt)
- 接口说明:获取执行一次绑定语句影响的行数。
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:返回受影响的行数。
- 接口说明:获取执行一次绑定语句影响的行数。
-
int32_t ws_stmt_close(WS_STMT *stmt)
- 接口说明:执行完毕,释放所有资源。
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:执行完毕,释放所有资源。
-
const char *ws_stmt_errstr(WS_STMT *stmt)
- 接口说明:用于在其他 STMT API 返回错误(返回错误码或空指针)时获取错误信息。
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:返回一个指向包含错误信息的字符串的指针。
- 接口说明:用于在其他 STMT API 返回错误(返回错误码或空指针)时获取错误信息。
无模式写入
除了使用 SQL 方式或者使用参数绑定 API 写入数据外,还可以使用 Schemaless 的方式完成写入。Schemaless 可以免于预先创建超级表/数据子表的数据结构,而是可以直接写入数据,TDengine 系统会根据写入的数据内容自动创建和维护所需要的表结构。Schemaless 的使用方式详见 Schemaless 写入 章节,这里介绍与之配套使用的 C/C++ API。
-
WS_RES *ws_schemaless_insert_raw(WS_TAOS *taos, const char *lines, int len, int32_t *totalRows, int protocol, int precision)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
ws_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- len:[入参] 数据缓冲区 lines 的总长度(字节数)。
- totalRows:[出参] 指向一个整数指针,用于返回成功插入的记录总数。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 WS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
ws_errstr()
获得错误信息,也可以使用ws_errno()
获得错误码。在某些情况下,返回的 WS_RES 为NULL
,此时仍然可以调用ws_errno()
来安全地获得错误码信息。
返回的 WS_RES 需要调用方来负责释放,否则会出现内存泄漏。
说明
协议类型是枚举类型,包含以下三种格式:- WS_TSDB_SML_LINE_PROTOCOL:InfluxDB 行协议(Line Protocol)
- WS_TSDB_SML_TELNET_PROTOCOL:OpenTSDB Telnet 文本行协议
- WS_TSDB_SML_JSON_PROTOCOL:OpenTSDB Json 协议格式
时间戳分辨率的定义,定义在
taosws.h
文件中,具体内容如下:- WS_TSDB_SML_TIMESTAMP_NOT_CONFIGURED = 0,
- WS_TSDB_SML_TIMESTAMP_HOURS,
- WS_TSDB_SML_TIMESTAMP_MINUTES,
- WS_TSDB_SML_TIMESTAMP_SECONDS,
- WS_TSDB_SML_TIMESTAMP_MILLI_SECONDS,
- WS_TSDB_SML_TIMESTAMP_MICRO_SECONDS,
- WS_TSDB_SML_TIMESTAMP_NANO_SECONDS
需要注意的是,时间戳分辨率参数只在协议类型为
WS_SML_LINE_PROTOCOL
的时候生效。
对于 OpenTSDB 的文本协议,时间戳的解析遵循其官方解析规则 — 按照时间戳包含的字符的数量来确认时间精度。schemaless 其他相关的接口
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。
-
WS_RES *ws_schemaless_insert_raw_with_reqid(WS_TAOS *taos, const char *lines, int len, int32_t *totalRows, int protocol, int precision, uint64_t reqid)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递参数 reqid 来跟踪整个的函数调用链情况。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
ws_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- len:[入参] 数据缓冲区 lines 的总长度(字节数)。
- totalRows:[出参] 指向一个整数指针,用于返回成功插入的记录总数。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- reqid:[入参] 指定的请求 ID,用于跟踪调用请求。请求 ID (reqid) 可以用于在客户端和服务器端之间建立请求和响应之间的关联,对于分布式系统中的跟踪和调试非常有用。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 WS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
ws_errstr()
获得错误信息,也可以使用ws_errno()
获得错误码。在某些情况下,返回的 WS_RES 为NULL
,此时仍然可以调用ws_errno()
来安全地获得错误码信息。
返回的 WS_RES 需要调用方来负责释放,否则会出现内存泄漏。
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递参数 reqid 来跟踪整个的函数调用链情况。
-
WS_RES *ws_schemaless_insert_raw_ttl(WS_TAOS *taos, const char *lines, int len, int32_t *totalRows, int protocol, int precision, int ttl)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递 ttl 参数来控制建表的 ttl 到期时间。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
ws_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- len:[入参] 数据缓冲区 lines 的总长度(字节数)。
- totalRows:[出参] 指向一个整数指针,用于返回成功插入的记录总数。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- ttl:[入参] 指定的生存时间(TTL),单位为天。记录在超过这个生存时间后会被自动删除。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 WS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
ws_errstr()
获得错误信息,也可以使用ws_errno()
获得错误码。在某些情况下,返回的 WS_RES 为NULL
,此时仍然可以调用ws_errno()
来安全地获得错误码信息。
返回的 WS_RES 需要调用方来负责释放,否则会出现内存泄漏。
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递 ttl 参数来控制建表的 ttl 到期时间。
-
WS_RES *ws_schemaless_insert_raw_ttl_with_reqid(WS_TAOS *taos, const char *lines, int len, int32_t *totalRows, int protocol, int precision, int ttl, uint64_t reqid)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递 ttl 参数来控制建表的 ttl 到期时间。通过传递参数 reqid 来跟踪整个的函数调用链情况。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
ws_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- len:[入参] 数据缓冲区 lines 的总长度(字节数)。
- totalRows:[出参] 指向一个整数指针,用于返回成功插入的记录总数。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- ttl:[入参] 指定的生存时间(TTL),单位为天。记录在超过这个生存时间后会被自动删除。
- reqid:[入参] 指定的请求 ID,用于跟踪调用请求。请求 ID (reqid) 可以用于在客户端和服务器端之间建立请求和响应之间的关联,对于分布式系统中的跟踪和调试非常有用。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 WS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
ws_errstr()
获得错误信息,也可以使用ws_errno()
获得错误码。在某些情况下,返回的 WS_RES 为NULL
,此时仍然可以调用ws_errno()
来安全地获得错误码信息。
返回的 WS_RES 需要调用方来负责释放,否则会出现内存泄漏。
说明
- 上面这 3 个接口是扩展接口,主要用于在 schemaless 写入时传递 ttl、reqid 参数,可以根据需要使用。
- 带 ttl 的接口可以传递 ttl 参数来控制建表的 ttl 到期时间。
- 带 reqid 的接口可以通过传递 reqid 参数来追踪整个的调用链。
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递 ttl 参数来控制建表的 ttl 到期时间。通过传递参数 reqid 来跟踪整个的函数调用链情况。
数据订阅
-
const char *ws_tmq_errstr(ws_tmq_t *tmq)
- 接口说明:用于获取数据订阅的错误信息。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- 返回值:返回一个指向包含错误信息字符串的指针,返回值非 NULL,但是错误信息可能为空字符串。
- 接口说明:用于获取数据订阅的错误信息。
-
ws_tmq_conf_t *ws_tmq_conf_new(void);
- 接口说明:创建一个新的 TMQ 配置对象。
- 返回值:非
NULL
:成功,返回一个指向 ws_tmq_conf_t 结构体的指针,该结构体用于配置 TMQ 的行为和特性。NULL
:失败,可调用函数 ws_errstr(NULL) 获取更详细的错误信息。
-
enum ws_tmq_conf_res_t ws_tmq_conf_set(ws_tmq_conf_t *conf, const char *key, const char *value)
- 接口说明:设置 TMQ 配置对象中的配置项,用于配置消费参数。
- conf:[入参] 指向一个有效的 ws_tmq_conf_t 结构体指针,该结构体代表一个 TMQ 配置对象。
- key:[入参] 数配置项的键名。
- value:[入参] 配置项的值。
- 返回值:返回一个 ws_tmq_conf_res_t 枚举值,表示配置设置的结果。
- WS_TMQ_CONF_OK:成功设置配置项。
- WS_TMQ_CONF_INVALID_KEY:键值无效。
- WS_TMQ_CONF_UNKNOWN:键名无效。
- 接口说明:设置 TMQ 配置对象中的配置项,用于配置消费参数。
-
int32_t ws_tmq_conf_destroy(ws_tmq_conf_t *conf)
- 接口说明:销毁一个 TMQ 配置对象并释放相关资源。
- conf:[入参] 指向一个有效的 ws_tmq_conf_t 结构体指针,该结构体代表一个 TMQ 配置对象。
- 返回值:
0
:成功。非0
:失败,可调用函数ws_tmq_errstr(NULL)
获取更详细的错误信息。
- 接口说明:销毁一个 TMQ 配置对象并释放相关资源。
-
ws_tmq_list_t *ws_tmq_list_new(void)
- 接口说明:用于创建一个 ws_tmq_list_t 结构体,用于存储订阅的 topic。
- 返回值:非
NULL
:成功,返回一个指向 ws_tmq_list_t 结构体的指针。NULL
:失败,可调用函数ws_tmq_errstr(NULL)
获取更详细的错误信息。
-
int32_t ws_tmq_list_append(ws_tmq_list_t *list, const char *topic)
- 接口说明:用于向 ws_tmq_list_t 结构体中添加一个 topic。
- list:[入参] 指向一个有效的 ws_tmq_list_t 结构体指针,该结构体代表一个 TMQ 列表对象。
- topic:[入参] topic 名称。
- 返回值:
0
:成功。非0
:失败,可调用函数ws_tmq_errstr(NULL)
获取更详细的错误信息。
- 接口说明:用于向 ws_tmq_list_t 结构体中添加一个 topic。
-
int32_t ws_tmq_list_destroy(ws_tmq_list_t *list);
- 接口说明:用于销毁 ws_tmq_list_t 结构体,ws_tmq_list_new 的结果需要通过该接口销毁。
- list:[入参] 指向一个有效的 ws_tmq_list_t 结构体指针,该结构体代表一个 TMQ 列表对象。
- 返回值:
0
:成功。非0
:失败,可调用函数ws_tmq_errstr(NULL)
获取更详细的错误信息。
- 接口说明:用于销毁 ws_tmq_list_t 结构体,ws_tmq_list_new 的结果需要通过该接口销毁。
-
int32_t ws_tmq_list_get_size(ws_tmq_list_t *list);
- 接口说明:用于获取 ws_tmq_list_t 结构体中 topic 的个数。
- list:[入参] 指向一个有效的 ws_tmq_list_t 结构体指针,该结构体代表一个 TMQ 列表对象。
- 返回值:
>=0
:成功,返回 ws_tmq_list_t 结构体中 topic 的个数。-1
:失败,表示输入参数 list 为 NULL。
- 接口说明:用于获取 ws_tmq_list_t 结构体中 topic 的个数。
-
char **ws_tmq_list_to_c_array(const ws_tmq_list_t *list, uint32_t *topic_num);
- 接口说明:用于将 ws_tmq_list_t 结构体转换为 C 数组,数组每个元素为字符串指针。
- list:[入参] 指向一个有效的 ws_tmq_list_t 结构体指针,该结构体代表一个 TMQ 列表对象。
- topic_num:[入参] list 的元素个数。
- 返回值:非
NULL
:成功,返回 c 数组,每个元素是字符串指针,代表一个 topic 名称。NULL
:失败,表示输入参数 list 为 NULL。
- 接口说明:用于将 ws_tmq_list_t 结构体转换为 C 数组,数组每个元素为字符串指针。
-
ws_tmq_t *ws_tmq_consumer_new(ws_tmq_conf_t *conf, const char *dsn, char *errstr, int errstr_len)
- 接口说明:用于创建一个 ws_tmq_t 结构体,用于消费数据,消费完数据后需调用 tmq_consumer_close 关闭消费者。
- conf:[入参] 指向一个有效的 ws_tmq_conf_t 结构体指针,该结构体代表一个 TMQ 配置对象。
- dsn:[入参] dsn 信息字符串,具体可参考上面 DSN 章节。一个常见的合法 dsn 为 “tmq+ws://root:taosdata@localhost:6041”。
- errstr:[出参] 指向一个有效的字符缓冲区指针,用于接收创建过程中可能产生的错误信息。内存的申请/释放由调用者负责。
- errstrLen:[入参] 指定 errstr 缓冲区的大小(以字节为单位)。
- 返回值:非
NULL
:成功,返回一个指向 ws_tmq_t 结构体的指针,该结构体代表一个 TMQ 消费者对象。。NULL
:失败,错误信息存储在参数 errstr 中。
- 接口说明:用于创建一个 ws_tmq_t 结构体,用于消费数据,消费完数据后需调用 tmq_consumer_close 关闭消费者。
-
int32_t ws_tmq_subscribe(ws_tmq_t *tmq, const ws_tmq_list_t *topic_list)
- 接口说明:用于订阅 topic 列表,消费完数据后,需调用 ws_tmq_subscribe 取消订阅。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- topic_list:[入参] 指向一个有效的 ws_tmq_list_t 结构体指针,该结构体包含一个或多个主题名称,目前仅支持一个主题名称。
- 返回值:
0
:成功。非0
:失败,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
- 接口说明:用于订阅 topic 列表,消费完数据后,需调用 ws_tmq_subscribe 取消订阅。
-
int32_t ws_tmq_unsubscribe(ws_tmq_t *tmq)
- 接口说明:用于取消订阅的 topic 列表。需与 ws_tmq_subscribe 配合使用。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- 返回值:
0
:成功。非0
:失败,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
- 接口说明:用于取消订阅的 topic 列表。需与 ws_tmq_subscribe 配合使用。
-
WS_RES *ws_tmq_consumer_poll(ws_tmq_t *tmq, int64_t timeout)
- 接口说明:用于轮询消费数据,每一个消费者,只能单线程调用该接口。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- timeout:[入参] 轮询的超时时间,单位为毫秒,负数表示默认超时 1 秒。
- 返回值:非
NULL
:成功,返回一个指向 WS_RES 结构体的指针,该结构体包含了接收到的消息。NULL
:表示没有数据,可通过 ws_errno(NULL) 获取错误码,具体错误码参见参考手册。WS_RES 结果和 taos_query 返回结果一致,可通过查询的各种接口获取 WS_RES 里的信息,比如 schema 等。
- 接口说明:用于轮询消费数据,每一个消费者,只能单线程调用该接口。
-
int32_t ws_tmq_consumer_close(ws_tmq_t *tmq)
- 接口说明:用于关闭 ws_tmq_t 结构体。需与 ws_tmq_consumer_new 配合使用。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- 返回值:
0
:成功。非0
:失败,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
- 接口说明:用于关闭 ws_tmq_t 结构体。需与 ws_tmq_consumer_new 配合使用。
-
int32_t ws_tmq_get_topic_assignment(ws_tmq_t *tmq, const char *pTopicName, struct ws_tmq_topic_assignment **assignment, int32_t *numOfAssignment)
- 接口说明:返回当前 consumer 分配的 vgroup 的信息,每个 vgroup 的信息包括 vgId,wal 的最大最小 offset,以及当前消费到的 offset。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要查询分配信息的主题名称。
- assignment:[出参] 指向一个 tmq_topic_assignment 结构体指针的指针,用于接收分配信息。数据大小为 numOfAssignment,需要通过 tmq_free_assignment 接口释放。
- numOfAssignment:[出参] 指向一个整数指针,用于接收分配给该 consumer 有效的 vgroup 个数。
- 返回值:
0
:成功。非0
:失败,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
- 接口说明:返回当前 consumer 分配的 vgroup 的信息,每个 vgroup 的信息包括 vgId,wal 的最大最小 offset,以及当前消费到的 offset。
-
int32_t ws_tmq_free_assignment(struct ws_tmq_topic_assignment *pAssignment, int32_t numOfAssignment)
- 接口说明:返回当前 consumer 分配的 vgroup 的信息,每个 vgroup 的信息包括 vgId,wal 的最大最小 offset,以及当前消费到的 offset。
- pAssignment:[入参] 指向一个有效的 ws_tmq_topic_assignment 结构体数组的指针,该数组包含了 vgroup 分配信息。
- numOfAssignment:[入参] pAssignment 指向的数组元素个数。
- 返回值:
0
:成功。非0
:失败,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
- 接口说明:返回当前 consumer 分配的 vgroup 的信息,每个 vgroup 的信息包括 vgId,wal 的最大最小 offset,以及当前消费到的 offset。
-
int64_t ws_tmq_committed(ws_tmq_t *tmq, const char *pTopicName, int32_t vgId)
- 接口说明:获取 TMQ 消费者对象对特定 topic 和 vgroup 的已提交偏移量。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要查询已提交偏移量的主题名称。
- vgId:[入参] vgroup 的 ID。
- 返回值:
>=0
:成功,返回一个 int64_t 类型的值,表示已提交的偏移量。<0
:失败,返回值就是错误码,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
- 接口说明:获取 TMQ 消费者对象对特定 topic 和 vgroup 的已提交偏移量。
-
int32_t ws_tmq_commit_sync(ws_tmq_t *tmq, const WS_RES *rs)
- 接口说明:同步提交 TMQ 消费者对象处理的消息偏移量。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- rs:[入参] 指向一个有效的 WS_RES 结构体指针,该结构体包含了已处理的消息。如果为 NULL,提交当前 consumer 所有消费的 vgroup 的当前进度。
- 返回值:
0
:成功,已经成功提交偏移量。非0
:失败,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
- 接口说明:同步提交 TMQ 消费者对象处理的消息偏移量。
-
int32_t ws_tmq_commit_offset_sync(ws_tmq_t *tmq, const char *pTopicName, int32_t vgId, int64_t offset)
- 接口说明:同步提交 TMQ 消费者对象的特定主题和 vgroup 的偏移量。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要提交偏移量的主题名称。
- vgId:[入参] 虚拟组 vgroup 的 ID。
- offset:[入参] 要提交的偏移量。
- 返回值:
0
:成功,已经成功提交偏移量。非0
:失败,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
- 接口说明:同步提交 TMQ 消费者对象的特定主题和 vgroup 的偏移量。
-
int64_t ws_tmq_position(ws_tmq_t *tmq, const char *pTopicName, int32_t vgId)
-
接口说明:获取当前消费位置,即已消费到的数据位置的下一个位置。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要查询当前位置的主题名称。
- vgId:[入参] 虚拟组 vgroup 的 ID。
-
返回值:
>=0
:成功,返回一个 int64_t 类型的值,表示当前位置的偏移量。<0
:失败,返回值就是错误码,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。 -
int32_t ws_tmq_offset_seek(ws_tmq_t *tmq, const char *pTopicName, int32_t vgId, int64_t offset)
-
接口说明:将 TMQ 消费者对象在某个特定 topic 和 vgroup 的偏移量设置到指定的位置。
- tmq:[入参] 指向一个有效的 ws_tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要查询当前位置的主题名称。
- vgId:[入参] 虚拟组 vgroup 的 ID。
- offset:[入参] 虚拟组 vgroup 的 ID。
-
返回值:
0
:成功,非0
:失败,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
-
-
int64_t ws_tmq_get_vgroup_offset(const WS_RES *rs)
- 接口说明:从 TMQ 消费者获取的消息结果中提取虚拟组(vgroup)的当前消费数据位置的偏移量。
- res:[入参] 指向一个有效的 WS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:
>=0
:成功,返回一个 int64_t 类型的值,表示当前消费位置的偏移量。<0
:失败,返回值就是错误码,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
- 接口说明:从 TMQ 消费者获取的消息结果中提取虚拟组(vgroup)的当前消费数据位置的偏移量。
-
int32_t ws_tmq_get_vgroup_id(const WS_RES *rs)
- 接口说明:从 TMQ 消费者获取的消息结果中提取所属虚拟组(vgroup)的 ID。
- res:[入参] 指向一个有效的 WS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:
>=0
:成功,返回一个 int32_t 类型的值,表示虚拟组(vgroup)的 ID。<0
:失败,返回值就是错误码,可调用函数ws_tmq_errstr(tmq)
获取更详细的错误信息。
- 接口说明:从 TMQ 消费者获取的消息结果中提取所属虚拟组(vgroup)的 ID。
-
const char *ws_tmq_get_table_name(const WS_RES *rs)
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的表名。
- res:[入参] 指向一个有效的 WS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:非
NULL
:成功,返回一个 const char * 类型的指针,指向表名字符串。NULL
:失败,非法的输入参数。
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的表名。
-
enum ws_tmq_res_t ws_tmq_get_res_type(const WS_RES *rs)
- 接口说明:从 TMQ 消费者获取的消息结果中获取消息类型。
- res:[入参] 指向一个有效的 WS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:返回一个 ws_tmq_res_t 类型的枚举值,表示消息类型。
- ws_tmq_res_t 表示消费到的数据类型,定义如下:
typedef enum ws_tmq_res_t {WS_TMQ_RES_INVALID = -1, // 无效WS_TMQ_RES_DATA = 1, // 数据类型WS_TMQ_RES_TABLE_META = 2, // 元数据类型WS_TMQ_RES_METADATA = 3 // 既有元数据类型又有数据类型,即自动建表 } tmq_res_t;
- 接口说明:从 TMQ 消费者获取的消息结果中获取消息类型。
-
const char *ws_tmq_get_topic_name(const WS_RES *rs)
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的 topic 名称。
- res:[入参] 指向一个有效的 WS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:非
NULL
:成功,返回一个 const char * 类型的指针,指向 topic 名称字符串。NULL
:失败,非法的输入参数。
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的 topic 名称。
-
const char *ws_tmq_get_db_name(const WS_RES *rs)
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的数据库名称。
- res:[入参] 指向一个有效的 WS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:非
NULL
:成功,返回一个 const char * 类型的指针,指向数据库名称字符串。NULL
:失败,非法的输入参数。
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的数据库名称。
原生连接方式
原生连接方式需要使用 taos.h 头文件和 taos 动态库。
#include <taos.h>
TDengine 服务端或客户端安装后,taos.h
位于:
- Linux:
/usr/local/taos/include
- Windows:
C:\TDengine\include
- macOS:
/usr/local/include
TDengine 客户端驱动的动态库位于:
- Linux:
/usr/local/taos/driver/libtaos.so
- Windows:
C:\TDengine\driver\taos.dll
- macOS:
/usr/local/lib/libtaos.dylib
支持的平台
请参考 支持的平台列表
支持的版本
TDengine 客户端驱动的版本号与 TDengine 服务端的版本号是一一对应的强对应关系,建议使用与 TDengine 服务端完全相同的客户端驱动。虽然低版本的客户端驱动在前三段版本号一致(即仅第四段版本号不同)的情况下也能够与高版本的服务端相兼容,但这并非推荐用法。强烈不建议使用高版本的客户端驱动访问低版本的服务端。
错误码
在 C 接口的设计中,错误码采用整数类型表示,每个错误码都对应一个特定的错误状态。如未特别说明,当 API 的返回值是整数时,0 代表成功,其它是代表失败原因的错误码,当返回值是指针时,NULL 表示失败。
所有的错误码以及对应的原因描述在 taoserror.h
文件中。
详细的错误码说明参考:错误码
示例程序
本节展示了使用客户端驱动访问 TDengine 集群的常见访问方式的示例代码。
-
同步查询示例:同步查询
-
异步查询示例:异步查询
-
参数绑定示例:参数绑定
-
无模式写入示例:无模式写入
-
订阅和消费示例:订阅和消费
:::info
更多示例代码及下载请见 GitHub。
也可以在安装目录下的 examples/c
路径下找到。该目录下有 makefile,在 Linux/macOS 环境下,直接执行 make 就可以编译得到执行文件。
**提示:**在 ARM 环境下编译时,请将 makefile 中的 -msse4.2
去掉,这个选项只有在 x64/x86 硬件平台上才能支持。
:::
API 参考
以下分别介绍 TDengine 客户端驱动的基础 API、同步 API、异步 API、参数绑定 API,无模式写入 API 和数据订阅 API。
基础 API
基础 API 用于完成创建数据库连接等工作,为其它 API 的执行提供运行时环境。
-
int taos_init()
- 接口说明:初始化运行环境。如果没有主动调用该 API,那么调用
taos_connect()
时驱动将自动调用该 API,故程序一般无需手动调用。 - 返回值:
0
:成功,非0
:失败,可调用函数 taos_errstr(NULL) 获取更详细的错误信息。
- 接口说明:初始化运行环境。如果没有主动调用该 API,那么调用
-
void taos_cleanup()
- 接口说明:清理运行环境,应用退出前应调用。
-
int taos_options(TSDB_OPTION option, const void * arg, ...)
- 接口说明:设置客户端选项,支持区域设置(
TSDB_OPTION_LOCALE
)、字符集设置(TSDB_OPTION_CHARSET
)、时区设置(TSDB_OPTION_TIMEZONE
)、配置文件路径设置(TSDB_OPTION_CONFIGDIR
)、驱动类型设置(TSDB_OPTION_DRIVER
)。区域设置、字符集、时区默认为操作系统当前设置。驱动类型可选内部原生接口(native
)和 WebSocket 接口(websocket
),默认为websocket
。 - 参数说明:
option
:[入参] 设置项类型。arg
:[入参] 设置项值。
- 返回值:
0
:成功,-1
:失败。
- 接口说明:设置客户端选项,支持区域设置(
-
int taos_options_connection(TAOS *taos, TSDB_OPTION_CONNECTION option, const void *arg, ...)
- 接口说明:设置客户端连接选项,目前支持字符集设置(
TSDB_OPTION_CONNECTION_CHARSET
)、时区设置(TSDB_OPTION_CONNECTION_TIMEZONE
)、用户 IP 设置(TSDB_OPTION_CONNECTION_USER_IP
)、用户 APP 设置(TSDB_OPTION_CONNECTION_USER_APP
)。 - 参数说明:
taos
:[入参] taos_connect 返回的连接句柄。option
:[入参] 设置项类型。arg
:[入参] 设置项值。
- 返回值:
0
:成功,非0
:失败。 - 说明:
- 字符集、时区默认为操作系统当前设置,windows 不支持连接级别的时区设置。
- arg 为 NULL 时表示重置该选项。
- 该接口只对当前连接有效,不会影响其他连接。
- 同样参数多次调用该接口,以后面的为准,可以作为修改的方法。
- TSDB_OPTION_CONNECTION_CLEAR 选项用于重置所有连接选项。
- 时区和字符集重置后,使用系统的设置,user ip 和 user app 重置后为空。
- 连接选项的值都是 string 类型,user app 参数值最大长度为 23,超过该长度会被截断;其他参数非法时报错。
- 时区配置找不到时区文件或者不能按照规范解释时,默认为 UTC,和操作系统时区规则相同,详见 tzset 函数说明。可通过 select timezone() 查看当前连接的时区。
- 时区和字符集只在 client 侧起作用,对于在服务端的相关行为不起作用。
- 时区文件使用操作系统时区文件,可以自行更新操作系统时区文件。如果设置时区报错,请检查是否有时区文件或路径(mac:/var/db/timezone/zoneinfo, linux:/usr/share/zoneinfo)是否正确。
- 接口说明:设置客户端连接选项,目前支持字符集设置(
-
char *taos_get_client_info()
- 接口说明:获取客户端版本信息。
- 返回值:返回客户端版本信息。
-
TAOS *taos_connect(const char *ip, const char *user, const char *pass, const char *db, uint16_t port);
- 接口说明:创建数据库连接,初始化连接上下文。
- 参数说明:
- ip:[入参] TDengine 集群中任一节点的 FQDN。
- user:[入参] 用户名。
- pass:[入参] 密码。
- db:[入参] 数据库名字,如果用户没有提供,也可以正常连接,用户可以通过该连接创建新的数据库,如果用户提供了数据库名字,则说明该数据库用户已经创建好,缺省使用该数据库。
- port:[入参] taosd 程序监听的端口。
- 返回值:返回数据库连接,返回值为空表示失败。应用程序需要保存返回的参数,以便后续使用。
:::info
同一进程可以根据不同的 host/port 连接多个 TDengine 集群
:::
-
TAOS *taos_connect_auth(const char *host, const char *user, const char *auth, const char *db, uint16_t port)
- 接口说明:功能同 taos_connect。除 pass 参数替换为 auth 外,其他参数同 taos_connect。
- 参数说明:
- ip:[入参] TDengine 集群中任一节点的 FQDN。
- user:[入参] 用户名。
- auth:[入参] 原始密码取 32 位小写 md5。
- db:[入参] 数据库名称,如果用户没有提供,也可以正常连接,用户可以通过该连接创建新的数据库,如果用户提供了数据库名字,则说明该数据库用户已经创建好,缺省使用该数据库。
- port:[入参] taosd 程序监听的端口。
- 返回值:返回数据库连接,返回值为空表示失败。应用程序需要保存返回的参数,以便后续使用。
-
char *taos_get_server_info(TAOS *taos)
- 接口说明:获取服务端版本信息。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回获取服务端版本信息。
-
int taos_select_db(TAOS *taos, const char *db)
- 接口说明:将当前的缺省数据库设置为
db
。 - 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - db:[入参] 数据库名称。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:
0
:成功,非0
:失败,详情请参考错误码页面。
- 接口说明:将当前的缺省数据库设置为
-
int taos_get_current_db(TAOS *taos, char *database, int len, int *required)
- 接口说明:获取当前数据库名称。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - database:[出参] 存储当前数据库名称。
- len:[入参] database 的空间大小。
- required:[出参] 存储当前数据库名称所需的空间(包含最后的’\0’)。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:
0
:成功,-1
:失败,可调用函数 taos_errstr(NULL) 获取更详细的错误信息。- 如果,database == NULL 或者 len<=0 返回失败。
- 如果,len 小于 存储数据库名称所需的空间(包含最后的’\0’),返回失败,database 里赋值截断的数据,以’\0’结尾。
- 如果,len 大于等于 存储数据库名称所需的空间(包含最后的’\0’),返回成功,database 里赋值以’\0‘结尾数据库名称。
-
int taos_set_notify_cb(TAOS *taos, __taos_notify_fn_t fp, void *param, int type)
- 接口说明:设置事件回调函数。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - fp:[入参] 事件回调函数指针。函数声明:typedef void (*__taos_notify_fn_t)(void *param, void *ext, int type);其中,param 为用户自定义参数,ext 为扩展参数 (依赖事件类型,针对 TAOS_NOTIFY_PASSVER 返回用户密码版本),type 为事件类型。
- param:[入参] 用户自定义参数。
- type:[入参] 事件类型。取值范围:1)TAOS_NOTIFY_PASSVER:用户密码改变。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:
0
:成功,-1
:失败,可调用函数 taos_errstr(NULL) 获取更详细的错误信息。
-
void taos_close(TAOS *taos)
- 接口说明:关闭连接。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
同步查询
本小节介绍 API 均属于同步接口。应用调用后,会阻塞等待响应,直到获得返回结果或错误信息。
-
TAOS_RES* taos_query(TAOS *taos, const char *sql)
- 接口说明:执行 SQL 语句,可以是 DQL、DML 或 DDL 语句。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - sql:[入参] 需要执行 SQL 语句。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:不能通过返回值是否是
NULL
来判断执行结果是否失败,而是需要调用taos_errno()
函数解析结果集中的错误代码来进行判断。- taos_errno 返回值:
0
:成功,-1
:失败,详情请调用 taos_errstr 函数来获取错误提示。
- taos_errno 返回值:
-
int taos_result_precision(TAOS_RES *res)
- 接口说明:返回结果集时间戳字段的精度类别。
- 参数说明:
- res:[入参] 结果集。
- 返回值:
0
:毫秒,1
:微秒,2
:纳秒。
-
TAOS_ROW taos_fetch_row(TAOS_RES *res)
- 接口说明:按行获取查询结果集中的数据。
- 参数说明:
- res:[入参] 结果集。
- 返回值:非
NULL
:成功,NULL
:失败,可调用函数 taos_errstr(NULL) 获取更详细的错误信息。
-
int taos_fetch_block(TAOS_RES *res, TAOS_ROW *rows)
- 接口说明:批量获取查询结果集中的数据。
- 参数说明:
- res:[入参] 结果集。
- rows:[出参] 用于存储从结果集中获取的行。
- 返回值:返回值为获取到的数据的行数,如果没有更多的行则返回 0。
-
int taos_num_fields(TAOS_RES *res)
和int taos_field_count(TAOS_RES *res)
- 接口说明:这两个 API 等价,用于获取查询结果集中的列数。
- 参数说明:
- res:[入参] 结果集。
- 返回值:返回值为结果集中列的数量。
-
int* taos_fetch_lengths(TAOS_RES *res)
- 接口说明:获取结果集中每个字段的长度。
- 参数说明:
- res:[入参] 结果集。
- 返回值:返回值是一个数组,其长度为结果集的列数。
-
int taos_affected_rows(TAOS_RES *res)
- 接口说明:获取被所执行的 SQL 语句影响的行数。
- 参数说明:
- res:[入参] 结果集。
- 返回值:返回值表示受影响的行数。
-
TAOS_FIELD *taos_fetch_fields(TAOS_RES *res)
- 接口说明:获取查询结果集每列数据的属性(列的名称、列的数据类型、列的长度),与
taos_num_fields()
配合使用,可用来解析taos_fetch_row()
返回的一个元组 (一行) 的数据。 - 参数说明:
- res:[入参] 结果集。
- 返回值:非
NULL
:成功,返回一个指向 TAOS_FIELD 结构体的指针,每个元素代表一列的元数据。NULL
:失败。
- 接口说明:获取查询结果集每列数据的属性(列的名称、列的数据类型、列的长度),与
-
TAOS_FIELD_E *taos_fetch_fields_e(TAOS_RES *res)
- 接口说明:获取查询结果集每列数据的属性(列的名称、列的数据类型、列的长度),与
taos_num_fields()
配合使用,可用来解析taos_fetch_row()
返回的一个元组 (一行) 的数据。TAOS_FIELD_E 中 除了 TAOS_FIELD 的基本信息外,还包括了类型的precision
和scale
信息。 - 参数说明:
- res:[入参] 结果集。
- 返回值:非
NULL
:成功,返回一个指向 TAOS_FIELD_E 结构体的指针,每个元素代表一列的元数据。NULL
:失败。
- 接口说明:获取查询结果集每列数据的属性(列的名称、列的数据类型、列的长度),与
-
void taos_stop_query(TAOS_RES *res)
- 接口说明:停止当前查询的执行。
- 参数说明:
- res:[入参] 结果集。
-
void taos_free_result(TAOS_RES *res)
- 接口说明:释放查询结果集以及相关的资源。查询完成后,务必调用该 API 释放资源,否则可能导致应用内存泄露。但也需注意,释放资源后,如果再调用
taos_consume()
等获取查询结果的函数,将导致应用崩溃。 - 参数说明:
- res:[入参] 结果集。
- 接口说明:释放查询结果集以及相关的资源。查询完成后,务必调用该 API 释放资源,否则可能导致应用内存泄露。但也需注意,释放资源后,如果再调用
-
char *taos_errstr(TAOS_RES *res)
- 接口说明:获取最近一次 API 调用失败的原因,返回值为字符串标识的错误提示信息。
- 参数说明:
- res:[入参] 结果集。
- 返回值:字符串标识的错误提示信息。
-
int taos_errno(TAOS_RES *res)
- 接口说明:获取最近一次 API 调用失败的原因,返回值为错误代码。
- 参数说明:
- res:[入参] 结果集。
- 返回值:字符串标识的错误提示信息。
:::note
2.0 及以上版本 TDengine 推荐数据库应用的每个线程都建立一个独立的连接,或基于线程建立连接池。而不推荐在应用中将该连接 (TAOS*) 结构体传递到不同的线程共享使用。基于 TAOS 结构体发出的查询、写入等操作具有多线程安全性,但“USE statement”等状态量有可能在线程之间相互干扰。此外,C 语言的连接器可以按照需求动态建立面向数据库的新连接(该过程对用户不可见),同时建议只有在程序最后退出的时候才调用 taos_close()
关闭连接。
另一个需要注意的是,在上述同步 API 执行过程中,不能调用类似 pthread_cancel 之类的 API 来强制结束线程,因为涉及一些模块的同步操作,如果强制结束线程有可能造成包括但不限于死锁等异常状况。
:::
异步查询
TDengine 还提供性能更高的异步 API 处理数据插入、查询操作。在软硬件环境相同的情况下,异步 API 处理数据插入的速度比同步 API 快 2 ~ 4 倍。异步 API 采用非阻塞式的调用方式,在系统真正完成某个具体数据库操作前,立即返回。调用的线程可以去处理其他工作,从而可以提升整个应用的性能。异步 API 在网络延迟严重的情况下,优势尤为突出。
异步 API 都需要应用提供相应的回调函数,回调函数参数设置如下:前两个参数都是一致的,第三个参数依不同的 API 而定。第一个参数 param 是应用调用异步 API 时提供给系统的,用于回调时,应用能够找回具体操作的上下文,依具体实现而定。第二个参数是 SQL 操作的结果集,如果为空,比如 insert 操作,表示没有记录返回,如果不为空,比如 select 操作,表示有记录返回。
异步 API 对于使用者的要求相对较高,用户可根据具体应用场景选择性使用。下面是两个重要的异步 API:
-
void taos_query_a(TAOS *taos, const char *sql, void (*fp)(void *param, TAOS_RES *, int code), void *param);
- 接口说明:异步执行 SQL 语句。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - sql:[入参] 需要执行的 SQL 语句。
- fp:用户定义的回调函数,其第三个参数
code
用于指示操作是否成功,0
表示成功,负数表示失败(调用taos_errstr()
可获取失败原因)。应用在定义回调函数的时候,主要处理第二个参数TAOS_RES *
,该参数是查询返回的结果集。 - param:应用提供的用于回调的参数。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
-
void taos_fetch_rows_a(TAOS_RES *res, void (*fp)(void *param, TAOS_RES *, int numOfRows), void *param);
- 接口说明:批量获取异步查询的结果集,只能与
taos_query_a()
配合使用。 - 参数说明:
- res:
taos_query_a()
回调时返回的结果集。 - fp:回调函数。其参数
param
是用户可定义的传递给回调函数的参数结构体;numOfRows
是获取到的数据的行数(不是整个查询结果集的函数)。在回调函数中,应用可以通过调用taos_fetch_row()
前向迭代获取批量记录中每一行记录。读完一块内的所有记录后,应用需要在回调函数中继续调用taos_fetch_rows_a()
获取下一批记录进行处理,直到返回的记录数numOfRows
为零(结果返回完成)或记录数为负值(查询出错)。
- res:
- 接口说明:批量获取异步查询的结果集,只能与
TDengine 的异步 API 均采用非阻塞调用模式。应用程序可以用多线程同时打开多张表,并可以同时对每张打开的表进行查询或者插入操作。需要指出的是,客户端应用必须确保对同一张表的操作完全串行化,即对同一个表的插入或查询操作未完成时(未返回时),不能够执行第二个插入或查询操作。
参数绑定
除了直接调用 taos_query()
进行查询,TDengine 也提供了支持参数绑定的 Prepare API,风格与 MySQL 类似,目前也仅支持用问号 ?
来代表待绑定的参数。
从 2.1.1.0 和 2.1.2.0 版本开始,TDengine 大幅改进了参数绑定接口对数据写入(INSERT)场景的支持。这样在通过参数绑定接口写入数据时,就避免了 SQL 语法解析的资源消耗,从而在绝大多数情况下显著提升写入性能。此时的典型操作步骤如下:
- 调用
taos_stmt_init()
创建参数绑定对象; - 调用
taos_stmt_prepare()
解析 INSERT 语句; - 如果 INSERT 语句中预留了表名但没有预留 TAGS,那么调用
taos_stmt_set_tbname()
来设置表名; - 如果 INSERT 语句中既预留了表名又预留了 TAGS(例如 INSERT 语句采取的是自动建表的方式),那么调用
taos_stmt_set_tbname_tags()
来设置表名和 TAGS 的值; - 调用
taos_stmt_bind_param_batch()
以多行的方式设置 VALUES 的值,或者调用taos_stmt_bind_param()
以单行的方式设置 VALUES 的值; - 调用
taos_stmt_add_batch()
把当前绑定的参数加入批处理; - 可以重复第 3 ~ 6 步,为批处理加入更多的数据行;
- 调用
taos_stmt_execute()
执行已经准备好的批处理指令; - 执行完毕,调用
taos_stmt_close()
释放所有资源。
说明:如果 taos_stmt_execute()
执行成功,假如不需要改变 SQL 语句的话,那么是可以复用 taos_stmt_prepare()
的解析结果,直接进行第 3 ~ 6 步绑定新数据的。但如果执行出错,那么并不建议继续在当前的环境上下文下继续工作,而是建议释放资源,然后从 taos_stmt_init()
步骤重新开始。
接口相关的具体函数如下(也可以参考 prepare.c 文件中使用对应函数的方式):
-
TAOS_STMT* taos_stmt_init(TAOS *taos)
- 接口说明:初始化一个预编译的 SQL 语句对象。
- 参数说明:
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:非
NULL
:成功,返回一个指向 TAOS_STMT 结构体的指针,该结构体表示预编译的 SQL 语句对象。NULL
:失败,详情请调用 taos_stmt_errstr() 函数来获取错误提示。
-
int taos_stmt_prepare(TAOS_STMT *stmt, const char *sql, unsigned long length)
- 接口说明:解析一条预编译的 SQL 语句,将解析结果和参数信息绑定到 stmt 上。
- 参数说明:
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- sql:[入参] 需要解析的 SQL 语句。
- length:[入参] 参数 sql 的长度。如果参数 length 大于 0,将使用此参数作为 SQL 语句的长度,如等于 0,将自动判断 SQL 语句的长度。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
-
int taos_stmt_bind_param(TAOS_STMT *stmt, TAOS_MULTI_BIND *bind)
- 接口说明:绑定参数到一个预编译的 SQL 语句。不如
taos_stmt_bind_param_batch()
效率高,但可以支持非 INSERT 类型的 SQL 语句。 - 参数说明:
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- bind:[入参] 指向一个有效的 TAOS_MULTI_BIND 结构体指针,该结构体包含了要绑定到 SQL 语句中的参数列表。需保证此数组中的元素数量和顺序与 SQL 语句中的参数完全一致。TAOS_MULTI_BIND 的使用方法与 MySQL 中的 MYSQL_BIND 类似。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:绑定参数到一个预编译的 SQL 语句。不如
-
int taos_stmt_set_tbname(TAOS_STMT* stmt, const char* name)
- 接口说明:(2.1.1.0 版本新增,仅支持用于替换 INSERT 语句中的参数值)当 SQL 语句中的表名使用了
?
占位时,可以使用此函数绑定一个具体的表名。 - 参数说明:
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- name:[入参] 指向一个包含子表名称的字符串常量。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:(2.1.1.0 版本新增,仅支持用于替换 INSERT 语句中的参数值)当 SQL 语句中的表名使用了
-
int taos_stmt_set_tbname_tags(TAOS_STMT* stmt, const char* name, TAOS_MULTI_BIND* tags)
- 接口说明:(2.1.2.0 版本新增,仅支持用于替换 INSERT 语句中的参数值)当 SQL 语句中的表名和 TAGS 都使用了
?
占位时,可以使用此函数绑定具体的表名和具体的 TAGS 取值。最典型的使用场景是使用了自动建表功能的 INSERT 语句(目前版本不支持指定具体的 TAGS 列)。TAGS 参数中的列数量需要与 SQL 语句中要求的 TAGS 数量完全一致。 - 参数说明:
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- name:[入参] 指向一个包含子表名称的字符串常量。
- tags:[入参] 指向一个有效的 TAOS_MULTI_BIND 结构体指针,该结构体包含了子表标签的值。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:(2.1.2.0 版本新增,仅支持用于替换 INSERT 语句中的参数值)当 SQL 语句中的表名和 TAGS 都使用了
-
int taos_stmt_bind_param_batch(TAOS_STMT* stmt, TAOS_MULTI_BIND* bind)
- 接口说明:(2.1.1.0 版本新增,仅支持用于替换 INSERT 语句中的参数值)以多列的方式传递待绑定的数据,需要保证这里传递的数据列的顺序、列的数量与 SQL 语句中的 VALUES 参数完全一致。
- 参数说明:
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- bind:[入参] 指向一个有效的 TAOS_MULTI_BIND 结构体指针,该结构体包含了要批量绑定到 SQL 语句中的参数列表。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
-
int taos_stmt_add_batch(TAOS_STMT *stmt)
- 接口说明:将当前绑定的参数加入批处理中,调用此函数后,可以再次调用
taos_stmt_bind_param()
或taos_stmt_bind_param_batch()
绑定新的参数。需要注意,此函数仅支持 INSERT/IMPORT 语句,如果是 SELECT 等其他 SQL 语句,将返回错误。- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:将当前绑定的参数加入批处理中,调用此函数后,可以再次调用
-
int taos_stmt_execute(TAOS_STMT *stmt)
- 接口说明:执行准备好的语句。目前,一条语句只能执行一次。
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:执行准备好的语句。目前,一条语句只能执行一次。
-
int taos_stmt_affected_rows(TAOS_STMT *stmt)
- 接口说明:获取执行预编译 SQL 语句后受影响的行数。
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:返回受影响的行数。
- 接口说明:获取执行预编译 SQL 语句后受影响的行数。
-
int taos_stmt_affected_rows_once(TAOS_STMT *stmt)
- 接口说明:获取执行一次绑定语句影响的行数。
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:返回受影响的行数。
- 接口说明:获取执行一次绑定语句影响的行数。
-
TAOS_RES* taos_stmt_use_result(TAOS_STMT *stmt)
- 接口说明:获取语句的结果集。结果集的使用方式与非参数化调用时一致,使用完成后,应对此结果集调用
taos_free_result()
以释放资源。- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:非
NULL
:成功,返回一个指向查询结果集的指针。NULL
:失败,详情请调用 taos_stmt_errstr() 函数来获取错误提示。
- 接口说明:获取语句的结果集。结果集的使用方式与非参数化调用时一致,使用完成后,应对此结果集调用
-
int taos_stmt_close(TAOS_STMT *stmt)
- 接口说明:执行完毕,释放所有资源。
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:
0
:成功。非0
:失败,详情请参考错误码页面。
- 接口说明:执行完毕,释放所有资源。
-
char * taos_stmt_errstr(TAOS_STMT *stmt)
- 接口说明:(2.1.3.0 版本新增)用于在其他 STMT API 返回错误(返回错误码或空指针)时获取错误信息。
- stmt:[入参] 指向一个有效的预编译的 SQL 语句对象指针。
- 返回值:返回一个指向包含错误信息的字符串的指针。
- 接口说明:(2.1.3.0 版本新增)用于在其他 STMT API 返回错误(返回错误码或空指针)时获取错误信息。
无模式写入
除了使用 SQL 方式或者使用参数绑定 API 写入数据外,还可以使用 Schemaless 的方式完成写入。Schemaless 可以免于预先创建超级表/数据子表的数据结构,而是可以直接写入数据,TDengine 系统会根据写入的数据内容自动创建和维护所需要的表结构。Schemaless 的使用方式详见 Schemaless 写入 章节,这里介绍与之配套使用的 C/C++ API。
-
TAOS_RES* taos_schemaless_insert(TAOS* taos, const char* lines[], int numLines, int protocol, int precision)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- numLines:[入参] 文本数据的行数,不能为 0。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 TAOS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
taos_errstr()
获得错误信息,也可以使用taos_errno()
获得错误码。在某些情况下,返回的 TAOS_RES 为NULL
,此时仍然可以调用taos_errno()
来安全地获得错误码信息。
返回的 TAOS_RES 需要调用方来负责释放,否则会出现内存泄漏。
说明
协议类型是枚举类型,包含以下三种格式:
- TSDB_SML_LINE_PROTOCOL:InfluxDB 行协议(Line Protocol)
- TSDB_SML_TELNET_PROTOCOL:OpenTSDB Telnet 文本行协议
- TSDB_SML_JSON_PROTOCOL:OpenTSDB Json 协议格式
时间戳分辨率的定义,定义在
taos.h
文件中,具体内容如下:- TSDB_SML_TIMESTAMP_NOT_CONFIGURED = 0,
- TSDB_SML_TIMESTAMP_HOURS,
- TSDB_SML_TIMESTAMP_MINUTES,
- TSDB_SML_TIMESTAMP_SECONDS,
- TSDB_SML_TIMESTAMP_MILLI_SECONDS,
- TSDB_SML_TIMESTAMP_MICRO_SECONDS,
- TSDB_SML_TIMESTAMP_NANO_SECONDS
需要注意的是,时间戳分辨率参数只在协议类型为
SML_LINE_PROTOCOL
的时候生效。
对于 OpenTSDB 的文本协议,时间戳的解析遵循其官方解析规则 — 按照时间戳包含的字符的数量来确认时间精度。schemaless 其他相关的接口
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。
-
TAOS_RES *taos_schemaless_insert_with_reqid(TAOS *taos, char *lines[], int numLines, int protocol, int precision, int64_t reqid)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递参数 reqid 来跟踪整个的函数调用链情况。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- numLines:[入参] 文本数据的行数,不能为 0。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- reqid:[入参] 指定的请求 ID,用于跟踪调用请求。请求 ID (reqid) 可以用于在客户端和服务器端之间建立请求和响应之间的关联,对于分布式系统中的跟踪和调试非常有用。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 TAOS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
taos_errstr()
获得错误信息,也可以使用taos_errno()
获得错误码。在某些情况下,返回的 TAOS_RES 为NULL
,此时仍然可以调用taos_errno()
来安全地获得错误码信息。
返回的 TAOS_RES 需要调用方来负责释放,否则会出现内存泄漏。
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递参数 reqid 来跟踪整个的函数调用链情况。
-
TAOS_RES *taos_schemaless_insert_raw(TAOS *taos, char *lines, int len, int32_t *totalRows, int protocol, int precision)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- len:[入参] 数据缓冲区 lines 的总长度(字节数)。
- totalRows:[出参] 指向一个整数指针,用于返回成功插入的记录总数。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 TAOS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
taos_errstr()
获得错误信息,也可以使用taos_errno()
获得错误码。在某些情况下,返回的 TAOS_RES 为NULL
,此时仍然可以调用taos_errno()
来安全地获得错误码信息。
返回的 TAOS_RES 需要调用方来负责释放,否则会出现内存泄漏。
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。
-
TAOS_RES *taos_schemaless_insert_raw_with_reqid(TAOS *taos, char *lines, int len, int32_t *totalRows, int protocol, int precision, int64_t reqid)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递参数 reqid 来跟踪整个的函数调用链情况。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- len:[入参] 数据缓冲区 lines 的总长度(字节数)。
- totalRows:[出参] 指向一个整数指针,用于返回成功插入的记录总数。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- reqid:[入参] 指定的请求 ID,用于跟踪调用请求。请求 ID (reqid) 可以用于在客户端和服务器端之间建立请求和响应之间的关联,对于分布式系统中的跟踪和调试非常有用。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 TAOS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
taos_errstr()
获得错误信息,也可以使用taos_errno()
获得错误码。在某些情况下,返回的 TAOS_RES 为NULL
,此时仍然可以调用taos_errno()
来安全地获得错误码信息。
返回的 TAOS_RES 需要调用方来负责释放,否则会出现内存泄漏。
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递参数 reqid 来跟踪整个的函数调用链情况。
-
TAOS_RES *taos_schemaless_insert_ttl(TAOS *taos, char *lines[], int numLines, int protocol, int precision, int32_t ttl)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递 ttl 参数来控制建表的 ttl 到期时间。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- numLines:[入参] 文本数据的行数,不能为 0。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- ttl:[入参] 指定的生存时间(TTL),单位为天。记录在超过这个生存时间后会被自动删除。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 TAOS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
taos_errstr()
获得错误信息,也可以使用taos_errno()
获得错误码。在某些情况下,返回的 TAOS_RES 为NULL
,此时仍然可以调用taos_errno()
来安全地获得错误码信息。
返回的 TAOS_RES 需要调用方来负责释放,否则会出现内存泄漏。
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递 ttl 参数来控制建表的 ttl 到期时间。
-
TAOS_RES *taos_schemaless_insert_ttl_with_reqid(TAOS *taos, char *lines[], int numLines, int protocol, int precision, int32_t ttl, int64_t reqid)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递 ttl 参数来控制建表的 ttl 到期时间。通过传递参数 reqid 来跟踪整个的函数调用链情况。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- numLines:[入参] 文本数据的行数,不能为 0。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- ttl:[入参] 指定的生存时间(TTL),单位为天。记录在超过这个生存时间后会被自动删除。
- reqid:[入参] 指定的请求 ID,用于跟踪调用请求。请求 ID (reqid) 可以用于在客户端和服务器端之间建立请求和响应之间的关联,对于分布式系统中的跟踪和调试非常有用。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 TAOS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
taos_errstr()
获得错误信息,也可以使用taos_errno()
获得错误码。在某些情况下,返回的 TAOS_RES 为NULL
,此时仍然可以调用taos_errno()
来安全地获得错误码信息。
返回的 TAOS_RES 需要调用方来负责释放,否则会出现内存泄漏。
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递 ttl 参数来控制建表的 ttl 到期时间。通过传递参数 reqid 来跟踪整个的函数调用链情况。
-
TAOS_RES *taos_schemaless_insert_raw_ttl(TAOS *taos, char *lines, int len, int32_t *totalRows, int protocol, int precision, int32_t ttl)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递 ttl 参数来控制建表的 ttl 到期时间。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- len:[入参] 数据缓冲区 lines 的总长度(字节数)。
- totalRows:[出参] 指向一个整数指针,用于返回成功插入的记录总数。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- ttl:[入参] 指定的生存时间(TTL),单位为天。记录在超过这个生存时间后会被自动删除。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 TAOS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
taos_errstr()
获得错误信息,也可以使用taos_errno()
获得错误码。在某些情况下,返回的 TAOS_RES 为NULL
,此时仍然可以调用taos_errno()
来安全地获得错误码信息。
返回的 TAOS_RES 需要调用方来负责释放,否则会出现内存泄漏。
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递 ttl 参数来控制建表的 ttl 到期时间。
-
TAOS_RES *taos_schemaless_insert_raw_ttl_with_reqid(TAOS *taos, char *lines, int len, int32_t *totalRows, int protocol, int precision, int32_t ttl, int64_t reqid)
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递 ttl 参数来控制建表的 ttl 到期时间。通过传递参数 reqid 来跟踪整个的函数调用链情况。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
taos_connect()
函数建立。 - lines:[入参] 文本数据。满足解析格式要求的无模式文本字符串。
- len:[入参] 数据缓冲区 lines 的总长度(字节数)。
- totalRows:[出参] 指向一个整数指针,用于返回成功插入的记录总数。
- protocol:[入参] 行协议类型,用于标识文本数据格式。
- precision:[入参] 文本数据中的时间戳精度字符串。
- ttl:[入参] 指定的生存时间(TTL),单位为天。记录在超过这个生存时间后会被自动删除。
- reqid:[入参] 指定的请求 ID,用于跟踪调用请求。请求 ID (reqid) 可以用于在客户端和服务器端之间建立请求和响应之间的关联,对于分布式系统中的跟踪和调试非常有用。
- taos:[入参] 指向数据库连接的指针,数据库连接是通过
- 返回值:返回一个指向 TAOS_RES 结构体的指针,该结构体包含了插入操作的结果。应用可以通过使用
taos_errstr()
获得错误信息,也可以使用taos_errno()
获得错误码。在某些情况下,返回的 TAOS_RES 为NULL
,此时仍然可以调用taos_errno()
来安全地获得错误码信息。
返回的 TAOS_RES 需要调用方来负责释放,否则会出现内存泄漏。
说明
- 上面这 7 个接口是扩展接口,主要用于在 schemaless 写入时传递 ttl、reqid 参数,可以根据需要使用。
- 带_raw 的接口通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。totalRows 指针返回解析出来的数据行数。
- 带_ttl 的接口可以传递 ttl 参数来控制建表的 ttl 到期时间。
- 带_reqid 的接口可以通过传递 reqid 参数来追踪整个的调用链。
- 接口说明:执行无模式的批量插入操作,将行协议的文本数据写入到 TDengine 中。通过传递的参数 lines 指针和长度 len 来表示数据,为了解决原始接口数据包含’\0’而被截断的问题。通过传递 ttl 参数来控制建表的 ttl 到期时间。通过传递参数 reqid 来跟踪整个的函数调用链情况。
数据订阅
-
const char *tmq_err2str(int32_t code)
- 接口说明:用于将数据订阅的错误码转换为错误信息。
- code:[入参] 数据订阅的错误码。
- 返回值:返回一个指向包含错误信息字符串的指针,返回值非 NULL,但是错误信息可能为空字符串。
- 接口说明:用于将数据订阅的错误码转换为错误信息。
-
tmq_conf_t *tmq_conf_new()
- 接口说明:创建一个新的 TMQ 配置对象。
- 返回值:非
NULL
:成功,返回一个指向 tmq_conf_t 结构体的指针,该结构体用于配置 TMQ 的行为和特性。NULL
:失败,可调用函数 taos_errstr(NULL) 获取更详细的错误信息。
-
tmq_conf_res_t tmq_conf_set(tmq_conf_t *conf, const char *key, const char *value)
- 接口说明:设置 TMQ 配置对象中的配置项,用于配置消费参数。
- conf:[入参] 指向一个有效的 tmq_conf_t 结构体指针,该结构体代表一个 TMQ 配置对象。
- key:[入参] 数配置项的键名。
- value:[入参] 配置项的值。
- 返回值:返回一个 tmq_conf_res_t 枚举值,表示配置设置的结果。tmq_conf_res_t 定义如下:
typedef enum tmq_conf_res_t {TMQ_CONF_UNKNOWN = -2, // 键名无效TMQ_CONF_INVALID = -1, // 键值无效TMQ_CONF_OK = 0, // 成功设置配置项} tmq_conf_res_t;
- 接口说明:设置 TMQ 配置对象中的配置项,用于配置消费参数。
-
void tmq_conf_set_auto_commit_cb(tmq_conf_t *conf, tmq_commit_cb *cb, void *param)
- 接口说明:设置 TMQ 配置对象中的自动提交回调函数。
- conf:[入参] 指向一个有效的 tmq_conf_t 结构体指针,该结构体代表一个 TMQ 配置对象。
- cb:[入参] 指向一个有效的 tmq_commit_cb 回调函数指针,该函数将在消息被消费后调用以确认消息处理状态。
- param:[入参] 传递给回调函数的用户自定义参数。
- 设置自动提交回调函数的定义如下:
typedef void(tmq_commit_cb(tmq_t *tmq, int32_t code, void *param))
- 接口说明:设置 TMQ 配置对象中的自动提交回调函数。
-
void tmq_conf_destroy(tmq_conf_t *conf)
- 接口说明:销毁一个 TMQ 配置对象并释放相关资源。
- conf:[入参] 指向一个有效的 tmq_conf_t 结构体指针,该结构体代表一个 TMQ 配置对象。
- 接口说明:销毁一个 TMQ 配置对象并释放相关资源。
-
tmq_list_t *tmq_list_new()
- 接口说明:用于创建一个 tmq_list_t 结构体,用于存储订阅的 topic。
- 返回值:非
NULL
:成功,返回一个指向 tmq_list_t 结构体的指针。NULL
:失败,可调用函数 taos_errstr(NULL) 获取更详细的错误信息。
-
int32_t tmq_list_append(tmq_list_t *list, const char* topic)
- 接口说明:用于向 tmq_list_t 结构体中添加一个 topic。
- list:[入参] 指向一个有效的 tmq_list_t 结构体指针,该结构体代表一个 TMQ 列表对象。
- topic:[入参] topic 名称。
- 返回值:
0
:成功。非0
:失败,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:用于向 tmq_list_t 结构体中添加一个 topic。
-
void tmq_list_destroy(tmq_list_t *list)
- 接口说明:用于销毁 tmq_list_t 结构体,tmq_list_new 的结果需要通过该接口销毁。
- list:[入参] 指向一个有效的 tmq_list_t 结构体指针,该结构体代表一个 TMQ 列表对象。
- 接口说明:用于销毁 tmq_list_t 结构体,tmq_list_new 的结果需要通过该接口销毁。
-
int32_t tmq_list_get_size(const tmq_list_t *list)
- 接口说明:用于获取 tmq_list_t 结构体中 topic 的个数。
- list:[入参] 指向一个有效的 tmq_list_t 结构体指针,该结构体代表一个 TMQ 列表对象。
- 返回值:
>=0
:成功,返回 tmq_list_t 结构体中 topic 的个数。-1
:失败,表示输入参数 list 为 NULL。
- 接口说明:用于获取 tmq_list_t 结构体中 topic 的个数。
-
char **tmq_list_to_c_array(const tmq_list_t *list)
- 接口说明:用于将 tmq_list_t 结构体转换为 C 数组,数组每个元素为字符串指针。
- list:[入参] 指向一个有效的 tmq_list_t 结构体指针,该结构体代表一个 TMQ 列表对象。
- 返回值:非
NULL
:成功,返回 c 数组,每个元素是字符串指针,代表一个 topic 名称。NULL
:失败,表示输入参数 list 为 NULL。
- 接口说明:用于将 tmq_list_t 结构体转换为 C 数组,数组每个元素为字符串指针。
-
tmq_t *tmq_consumer_new(tmq_conf_t *conf, char *errstr, int32_t errstrLen)
- 接口说明:用于创建一个 tmq_t 结构体,用于消费数据,消费完数据后需调用 tmq_consumer_close 关闭消费者。
- conf:[入参] 指向一个有效的 tmq_conf_t 结构体指针,该结构体代表一个 TMQ 配置对象。
- errstr:[出参] 指向一个有效的字符缓冲区指针,用于接收创建过程中可能产生的错误信息。内存的申请/释放由调用者负责。
- errstrLen:[入参] 指定 errstr 缓冲区的大小(以字节为单位)。
- 返回值:非
NULL
:成功,返回一个指向 tmq_t 结构体的指针,该结构体代表一个 TMQ 消费者对象。。NULL
:失败,错误信息存储在参数 errstr 中。
- 接口说明:用于创建一个 tmq_t 结构体,用于消费数据,消费完数据后需调用 tmq_consumer_close 关闭消费者。
-
int32_t tmq_subscribe(tmq_t *tmq, const tmq_list_t *topic_list)
- 接口说明:用于订阅 topic 列表,消费完数据后,需调用 tmq_subscribe 取消订阅。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- topic_list:[入参] 指向一个有效的 tmq_list_t 结构体指针,该结构体包含一个或多个主题名称。
- 返回值:
0
:成功。非0
:失败,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:用于订阅 topic 列表,消费完数据后,需调用 tmq_subscribe 取消订阅。
-
int32_t tmq_unsubscribe(tmq_t *tmq)
- 接口说明:用于取消订阅的 topic 列表。需与 tmq_subscribe 配合使用。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- 返回值:
0
:成功。非0
:失败,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:用于取消订阅的 topic 列表。需与 tmq_subscribe 配合使用。
-
int32_t tmq_subscription(tmq_t *tmq, tmq_list_t **topic_list)
- 接口说明:用于获取订阅的 topic 列表。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- topic_list:[出参] 指向一个 tmq_list_t 结构体指针的指针,用于接收当前订阅的主题列表。
- 返回值:
0
:成功。非0
:失败,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:用于获取订阅的 topic 列表。
-
TAOS_RES *tmq_consumer_poll(tmq_t *tmq, int64_t timeout)
- 接口说明:用于轮询消费数据,每一个消费者,只能单线程调用该接口。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- timeout:[入参] 轮询的超时时间,单位为毫秒,负数表示默认超时 1 秒。
- 返回值:非
NULL
:成功,返回一个指向 TAOS_RES 结构体的指针,该结构体包含了接收到的消息。。NULL
:表示没有数据,可通过 taos_errno(NULL) 获取错误码,具体错误码参见参考手册。TAOS_RES 结果和 taos_query 返回结果一致,可通过查询的各种接口获取 TAOS_RES 里的信息,比如 schema 等。
- 接口说明:用于轮询消费数据,每一个消费者,只能单线程调用该接口。
-
int32_t tmq_consumer_close(tmq_t *tmq)
- 接口说明:用于关闭 tmq_t 结构体。需与 tmq_consumer_new 配合使用。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- 返回值:非
NULL
:成功,返回一个指向 TAOS_RES 结构体的指针,该结构体包含了接收到的消息。。NULL
:表示没有数据,可通过 taos_errno(NULL) 获取错误码,具体错误码参见参考手册。TAOS_RES 结果和 taos_query 返回结果一致,可通过查询的各种接口获取 TAOS_RES 里的信息,比如 schema 等。
- 接口说明:用于关闭 tmq_t 结构体。需与 tmq_consumer_new 配合使用。
-
int32_t tmq_get_topic_assignment(tmq_t *tmq, const char *pTopicName, tmq_topic_assignment **assignment, int32_t *numOfAssignment)
- 接口说明:返回当前 consumer 分配的 vgroup 的信息,每个 vgroup 的信息包括 vgId,wal 的最大最小 offset,以及当前消费到的 offset。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要查询分配信息的主题名称。
- assignment:[出参] 指向一个 tmq_topic_assignment 结构体指针的指针,用于接收分配信息。数据大小为 numOfAssignment,需要通过 tmq_free_assignment 接口释放。
- numOfAssignment:[出参] 指向一个整数指针,用于接收分配给该 consumer 有效的 vgroup 个数。
- 返回值:
0
:成功。非0
:失败,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:返回当前 consumer 分配的 vgroup 的信息,每个 vgroup 的信息包括 vgId,wal 的最大最小 offset,以及当前消费到的 offset。
-
void tmq_free_assignment(tmq_topic_assignment* pAssignment)
- 接口说明:返回当前 consumer 分配的 vgroup 的信息,每个 vgroup 的信息包括 vgId,wal 的最大最小 offset,以及当前消费到的 offset。
- pAssignment:[入参] 指向一个有效的 tmq_topic_assignment 结构体数组的指针,该数组包含了 vgroup 分配信息。
- 接口说明:返回当前 consumer 分配的 vgroup 的信息,每个 vgroup 的信息包括 vgId,wal 的最大最小 offset,以及当前消费到的 offset。
-
int64_t tmq_committed(tmq_t *tmq, const char *pTopicName, int32_t vgId)
- 接口说明:获取 TMQ 消费者对象对特定 topic 和 vgroup 的已提交偏移量。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要查询已提交偏移量的主题名称。
- vgId:[入参] vgroup 的 ID。
- 返回值:
>=0
:成功,返回一个 int64_t 类型的值,表示已提交的偏移量。<0
:失败,返回值就是错误码,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:获取 TMQ 消费者对象对特定 topic 和 vgroup 的已提交偏移量。
-
int32_t tmq_commit_sync(tmq_t *tmq, const TAOS_RES *msg)
- 接口说明:同步提交 TMQ 消费者对象处理的消息偏移量。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- msg:[入参] 指向一个有效的 TAOS_RES 结构体指针,该结构体包含了已处理的消息。如果为 NULL,提交当前 consumer 所有消费的 vgroup 的当前进度。
- 返回值:
0
:成功,已经成功提交偏移量。非0
:失败,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:同步提交 TMQ 消费者对象处理的消息偏移量。
-
void tmq_commit_async(tmq_t *tmq, const TAOS_RES *msg, tmq_commit_cb *cb, void *param)
- 接口说明:异步提交 TMQ 消费者对象处理的消息偏移量。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- msg:[入参] 指向一个有效的 TAOS_RES 结构体指针,该结构体包含了已处理的消息。如果为 NULL,提交当前 consumer 所有消费的 vgroup 的当前进度。
- cb:[入参] 一个回调函数指针,当提交完成时会被调用。
- param:[入参] 一个用户自定义的参数,将在回调函数中传递给 cb。
- 接口说明:异步提交 TMQ 消费者对象处理的消息偏移量。
-
int32_t tmq_commit_offset_sync(tmq_t *tmq, const char *pTopicName, int32_t vgId, int64_t offset)
- 接口说明:同步提交 TMQ 消费者对象的特定主题和 vgroup 的偏移量。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要提交偏移量的主题名称。
- vgId:[入参] 虚拟组 vgroup 的 ID。
- offset:[入参] 要提交的偏移量。
- 返回值:
0
:成功,已经成功提交偏移量。非0
:失败,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:同步提交 TMQ 消费者对象的特定主题和 vgroup 的偏移量。
-
void tmq_commit_offset_async(tmq_t *tmq, const char *pTopicName, int32_t vgId, int64_t offset, tmq_commit_cb *cb, void *param)
- 接口说明:异步提交 TMQ 消费者对象的特定主题和 vgroup 的偏移量。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要提交偏移量的主题名称。
- vgId:[入参] 虚拟组 vgroup 的 ID。
- offset:[入参] 要提交的偏移量。
- cb:[入参] 一个回调函数指针,当提交完成时会被调用。
- param:[入参] 一个用户自定义的参数,将在回调函数中传递给 cb。
- 接口说明:异步提交 TMQ 消费者对象的特定主题和 vgroup 的偏移量。
-
int64_t tmq_position(tmq_t *tmq, const char *pTopicName, int32_t vgId)
- 接口说明:获取当前消费位置,即已消费到的数据位置的下一个位置。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要查询当前位置的主题名称。
- vgId:[入参] 虚拟组 vgroup 的 ID。
- 返回值:
>=0
:成功,返回一个 int64_t 类型的值,表示当前位置的偏移量。<0
:失败,返回值就是错误码,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:获取当前消费位置,即已消费到的数据位置的下一个位置。
-
int32_t tmq_offset_seek(tmq_t *tmq, const char *pTopicName, int32_t vgId, int64_t offset)
- 接口说明:将 TMQ 消费者对象在某个特定 topic 和 vgroup 的偏移量设置到指定的位置。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- pTopicName:[入参] 要查询当前位置的主题名称。
- vgId:[入参] 虚拟组 vgroup 的 ID。
- offset:[入参] 虚拟组 vgroup 的 ID。
- 返回值:
0
:成功,非0
:失败,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:将 TMQ 消费者对象在某个特定 topic 和 vgroup 的偏移量设置到指定的位置。
-
int64_t tmq_get_vgroup_offset(TAOS_RES* res)
- 接口说明:从 TMQ 消费者获取的消息结果中提取虚拟组(vgroup)的当前消费数据位置的偏移量。
- res:[入参] 指向一个有效的 TAOS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:
>=0
:成功,返回一个 int64_t 类型的值,表示当前消费位置的偏移量。<0
:失败,返回值就是错误码,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:从 TMQ 消费者获取的消息结果中提取虚拟组(vgroup)的当前消费数据位置的偏移量。
-
int32_t tmq_get_vgroup_id(TAOS_RES *res)
- 接口说明:从 TMQ 消费者获取的消息结果中提取所属虚拟组(vgroup)的 ID。
- res:[入参] 指向一个有效的 TAOS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:
>=0
:成功,返回一个 int32_t 类型的值,表示虚拟组(vgroup)的 ID。<0
:失败,返回值就是错误码,可调用函数char *tmq_err2str(int32_t code)
获取更详细的错误信息。
- 接口说明:从 TMQ 消费者获取的消息结果中提取所属虚拟组(vgroup)的 ID。
-
TAOS *tmq_get_connect(tmq_t *tmq)
- 接口说明:从 TMQ 消费者对象中获取与 TDengine 数据库的连接句柄。
- tmq:[入参] 指向一个有效的 tmq_t 结构体指针,该结构体代表一个 TMQ 消费者对象。
- 返回值:非
NULL
:成功,返回一个 TAOS * 类型的指针,指向与 TDengine 数据库的连接句柄。NULL
:失败,非法的输入参数。
- 接口说明:从 TMQ 消费者对象中获取与 TDengine 数据库的连接句柄。
-
const char *tmq_get_table_name(TAOS_RES *res)
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的表名。
- res:[入参] 指向一个有效的 TAOS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:非
NULL
:成功,返回一个 const char * 类型的指针,指向表名字符串。NULL
:失败,非法的输入参数。
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的表名。
-
tmq_res_t tmq_get_res_type(TAOS_RES *res)
- 接口说明:从 TMQ 消费者获取的消息结果中获取消息类型。
- res:[入参] 指向一个有效的 TAOS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:返回一个 tmq_res_t 类型的枚举值,表示消息类型。
- tmq_res_t 表示消费到的数据类型,定义如下:
typedef enum tmq_res_t {TMQ_RES_INVALID = -1, // 无效TMQ_RES_DATA = 1, // 数据类型TMQ_RES_TABLE_META = 2, // 元数据类型TMQ_RES_METADATA = 3 // 既有元数据类型又有数据类型,即自动建表 } tmq_res_t;
- tmq_res_t 表示消费到的数据类型,定义如下:
- 接口说明:从 TMQ 消费者获取的消息结果中获取消息类型。
-
const char *tmq_get_topic_name(TAOS_RES *res)
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的 topic 名称。
- res:[入参] 指向一个有效的 TAOS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:非
NULL
:成功,返回一个 const char * 类型的指针,指向 topic 名称字符串。NULL
:失败,非法的输入参数。
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的 topic 名称。
-
const char *tmq_get_db_name(TAOS_RES *res)
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的数据库名称。
- res:[入参] 指向一个有效的 TAOS_RES 结构体指针,该结构体包含了从 TMQ 消费者轮询得到的消息。
- 返回值:非
NULL
:成功,返回一个 const char * 类型的指针,指向数据库名称字符串。NULL
:失败,非法的输入参数。
- 接口说明:从 TMQ 消费者获取的消息结果中获取所属的数据库名称。
访问官网
更多内容欢迎访问 TDengine 官网
相关文章:
TDengine.C/C++ 连接器
简介 C/C 开发人员可以使用 TDengine 的客户端驱动,即 C/C 连接器(以下都用 TDengine 客户端驱动表示),开发自己的应用来连接 TDengine 集群完成数据存储、查询以及其他功能。TDengine 客户端驱动的 API 类似于 MySQL 的 C API。…...
什么是混合搜索Hybrid Search?
🧠 向所有学习者致敬! “学习不是装满一桶水,而是点燃一把火。” —— 叶芝 我的博客主页: https://lizheng.blog.csdn.net 🌐 欢迎点击加入AI人工智能社区! 🚀 让我们一起努力,共创AI未来! 🚀 混合搜索通常指一种结合多种搜索方法或技术的搜索策略,旨在提供更…...
滤波器:模拟滤波器和数字滤波器的区别
滤波器是一种用于从信号中去除不需要的频率成分,只保留所需频率成分的电子设备或算法。根据实现方式的不同,滤波器主要分为模拟滤波器和数字滤波器两大类。以下是对这两种滤波器的详细比较: 一、实现方式与原理 模拟滤波器 实现方式…...
AudioRecord 录制pcm转wav
pcm转wav PCM 格式校验pcm 添加 wav 头信息WAVWAV 格式检验小端序? 参考地址 PCM 格式校验 /*** 专业PCM文件验证(支持动态参数与多格式)* param silenceThreshold 静音检测阈值(0.0~1.0),默认90%零值为静…...
625SJBH网上便利店的设计与实现
1前 言 目前,网络正以一种前所未有的冲击力在影响着人类的活动,包括人类的生产和日常生活。网络的诞生和发展,颠覆了传统的信息传播方式,冲破了存在于传统交流方式中时间和空间的种种壁垒,极大地改变了人类从物质到精…...
如何开发英语在线训练小程序:从0到1的详细步骤
在数字化学习的浪潮下,英语在线训练小程序凭借便捷、高效的学习模式,成为众多英语学习者的得力助手。如果你也想开发一款独具特色的英语在线训练小程序,不妨参考以下步骤,开启你的小程序开发之旅。 一、前期规划 (…...
java设计模式-装饰者模式
装饰者模式(Decorator) 定义 1、动态的将新功能附加到对象上,在对象功能扩展方面,他比继承更有弹性,也体现了开闭原则(OCP) 2、这里提到的动态的将新功能附加到对象和OCP原则,在后面应用实际上会以代码的形式体现。 //饮料 // 饮…...
我提了一个 Androidx IssueTracker
问题 在运行 gradle plugin 插件的 transform R8 阶段出现了报错 Caused by: com.android.tools.r8.internal.xk: java.lang.NullPointerException: Cannot invoke “String.length()” because “” is null 报错日志 FAILURE: Build failed with an exception.* What went w…...
spring mvc @ResponseBody 注解转换为 JSON 的原理与实现详解
ResponseBody 注解转换为 JSON 的原理与实现详解 1. 核心作用 ResponseBody 是 Spring MVC 的一个注解,用于将方法返回的对象直接序列化为 HTTP 响应体(如 JSON 或 XML),而不是通过视图解析器渲染为视图(如 HTML&…...
RK3588芯片NPU的使用:Windows11 Docker中运行MobileNet模型以及部署到开发板进行目标检测
本文的目标 本文将在RKNN Docker环境(见本系列的第二篇文章)中练习MobileNet图像分类示例,并通过adb工具部署到RK3588开发板。 MobileNet简介请参考上一篇文章。 开发环境说明 主机系统:Windows11目标设备:搭载RK35…...
智能仓储数字孪生Demo(Unity实现)
一、项目背景与行业痛点 医药流通行业仓储管理面临三大核心挑战: 合规性风险:GSP(药品经营质量管理规范)对温湿度、药品批次追溯的严苛要求,传统人工记录易出错效率瓶颈:库区布局复杂,人工巡检…...
Qt上hook钩子的使用,监测键盘和鼠标。
演示平台:windows。 编译环境:Qt5.12.2 MinGW 64-bit Windows API: ///加载钩子 /*** SetWindowsHookEx 函数解释* int idHook 所监控的挂钩类型* HOOKPROC lpfn 监控信息的处理函数* HINSTANCEhMod 监控信息的动态链接位置 nullptr则与本线…...
Android12源码编译之预置Android Studio项目Android.mk文件编写
1、在AndroidManifest.xml文件中添加package"com.sprd.silentinstalldemo"属性,因为新版本的Android Studio默认生成的AndroidManifest.xml是没有这个属性值的 <?xml version"1.0" encoding"utf-8"?> <manifest xmlns:an…...
微服务注册中心选择指南:Eureka vs Consul vs Zookeeper vs Nacos
文章目录 引言微服务注册中心概述什么是服务注册与发现选择注册中心的标准 常见的微服务注册中心1. Eureka1.1 理论基础1.2 特点1.3 示例代码 2. Consul2.1 理论基础2.2 特点2.3 示例代码 3. Zookeeper3.1 理论基础3.2 特点3.3 示例代码 4. Nacos4.1 理论基础4.2 特点4.3 示例代…...
pg_waldump无法定位WAL文件问题
目录 排查pg_waldump无法定位WAL文件问题的步骤1. 确认WAL文件路径配置2. 检查WAL文件名格式3. 验证文件存在性4. 检查文件权限5. 时间线历史文件检查6. 使用pg_controldata验证状态7. 尝试指定完整路径 典型错误场景及解决方案 排查pg_waldump无法定位WAL文件问题的步骤 1. 确…...
Mysql安装
Mysql安装 1. windows安装1.1 官网下载1.2 安装 1. windows安装 1.1 官网下载 官网下载 选择对于版本,然后跳转到下载页 1.2 安装...
Windows版-RabbitMQ自动化部署
一键完成Erlang环境变量配置(ERLANG_HOME系统变量) 一键完成RabbitMQ环境变量配置(RabbitMQ系统变量) 实现快速安装部署RabbitMQ PS: 需提前下载安装: - otp_win64_25.0.exe (Erlang) - rabbit…...
spring mvc的拦截器HandlerInterceptor 接口详解
HandlerInterceptor 接口详解 1. 接口方法说明 方法作用执行时机返回值/注意事项preHandle请求处理前拦截在控制器方法执行前调用返回 false 中断后续流程;返回 true 继续执行postHandle控制器方法执行后拦截在控制器方法返回结果后,视图渲染前调用无返…...
Linux平台内存泄漏检测工具介绍: ASan vs Valgrind
目录: 前言Valgrind 介绍在Ubuntu上安装Valgrind 核心主要功能Valgrind 基本用法1. --leak-checkfull2. --show-leak-kindsall3. --track-originsyes4. 其他常用选项--tool<name>--log-file<filename>-v / --verbose--error-exitcode<n> 示例命令…...
c# 数据结构 链表篇 有关单链表的一切
本人能力有限,本文仅作学习交流与参考,如有不足还请斧正 目录 0.单链表好处 0.5.单链表分类 1.无虚拟头节点情况 图示: 代码: 头插/尾插 删除 搜索 遍历全部 测试代码: 全部代码 2.有尾指针情况 尾插 全部代码 3.有虚拟头节点情况 全部代码 4.循环单链表 几个…...
二叉树层平均值:层序遍历+队列解法详解
给定一个非空二叉树的根节点 root , 以数组的形式返回每一层节点的平均值。与实际答案相差 10-5 以内的答案可以被接受。 示例 1: 输入:root [3,9,20,null,null,15,7] 输出:[3.00000,14.50000,11.00000] 解释:第 0 层的平均值为 …...
解决 Docker Swarm 集群节点故障:从问题剖析到修复实战
解决 Docker Swarm 集群节点故障:从问题剖析到修复实战 在使用 Docker Swarm 构建容器编排集群时,可能会遭遇各种难题。本文将分享一次处理 Docker Swarm 集群节点故障的实战经历,涵盖问题出现的缘由、详细剖析以及完整的解决步骤࿰…...
【Java中级】11章、注解、元注解介绍、快速入门,了解java注解的基本使用方式【2】
文章内容 JDK内置的基本注释类型 Override DeprecatedSuppressWarnings 元注解 对注释进行注解 ❤️内容涉及注解的定义,快速入门,注意事项 🌈 跟着B站一位老师学习的内部类内容,现写这篇文章为学习内部类的小伙伴提供思路支持&…...
Qt中自定义插件和库(1)
Qt中自定义插件和库(1) 在Qt中自定义插件和库的方法有两种: 1.提升法。 2.自定义Qt Designer 插件法。 下面就以《Qt 5.9 C开发指南》一书中的例子来讲解。下面先讲提升法。 一、提升法 提升法(Promotion)是Qt Designer中重用自定义控件的一种方法,…...
RK3568下QT实现视频播放器
在开发多媒体应用时,视频播放器是常见的项目。QT 作为一款跨平台的 C++ 应用程序开发框架,凭借丰富的类库和工具,让开发视频播放器变得简单。本文将介绍如何使用 QT 的QMediaPlayer和QVideoWidget类,实现一个简单的视频播放器,并逐步添加打开视频、播放、暂停、停止以及进…...
Shell脚本核心要点总结
刷题: Shell脚本核心要点总结 一、Shell基础 定义:Shell是用户与内核交互的接口,本质是多个指令的集合,需遵循逻辑关系。类型: 编译型语言(如C):需编译器(如gcc…...
C++-FFmpeg-(5)-1-ffmpeg原理-ffmpeg编码接口-AVFrame-AVPacket-最简单demo
1.视频编码原理 2.FFMpeg编码接口和AVPacket结构体详解 2.1ffmpeg编码接口 -编码器上下文 2.2AVPacket结构体 2.3AVFrame结构体 3.视频播放最简单demo 3.1FFMpeg编码器获取和上下文打开 3.2视频帧创建和测试 1.视频编码原理 1.1 流程:像素格式转换-&…...
Opencv计算机视觉编程攻略-第十二节 处理视频序列
视频由一系列图像构成,这些图像称为帧,帧是以固定时间间隔获取的(称为帧速率,通常用帧/秒表示,例如大疆无人机抽取每一帧),本文将介绍如何读取、处理和存储视频序列。如果从视频序列中提取出独立…...
浮点许可优化管理软件 - 智能许可管理专家
为什么选择浮点许可优化管理软件? 在当今数字化时代,企业软件许可支出持续攀升,如何实现许可资源的最优配置成为一大挑战。浮点许可优化管理软件通过先进的算法和自动化技术,帮助企业实现许可资源的精准管理和成本优化。 革命性的智能化功能…...
Spring Boot接口返回Long类型的数据时丢失精度的全局处理
1、问题 当实体类中的字段为Long类型时,通过Ajax请求返回给前段,在js中数据会丢失精度 直接通过postman请求或通过浏览器请求,看下响应则不会丢失精度 2、处理方式 1、使用JsonSerialize注解 JsonSerialize(using ToStringSerializer.…...
量子计算入门:开启未来计算的次元之门
在科幻电影中,我们常看到“量子计算机”被描绘成无所不能的黑科技——破解密码、模拟宇宙、瞬间完成超算百年的任务。但现实中,量子计算究竟是什么?它真的能颠覆传统计算机吗? 一、从“硬币”到“薛定谔的猫”:量子世界…...
学习日志37—基于变分量子电路的量子机器学习算法综述
基于变分量子电路的量子机器学习算法综述 论文原链接参考:https://crad.ict.ac.cn/article/cstr/32373.14.issn1000-1239.202330979 这篇综述的核心内容是基于变分量子电路(VQCs)的量子机器学习算法的研究现状、应用进展以及面临的挑战和未…...
初入Web网页开发
1、网页哪些内容 1.1 三个核心文件的作用 index.html:网页的骨架,用HTML编写网页结构和内容。 script.js:网页的行为,用JavaScript实现交互功能(如按钮点击事件)。 styles.css:网页的外观&…...
Vue进行前端开发流程
一、创建vue项目 创建vue项目:先进入要操作的目录下,注意本项目是用vue2开发的。 vue create vue项目名 二、项目开发 1.创建项目结构 2.开发功能模块 主入口App.vue <template><div class"boss-app"><Header /><m…...
【深度学习:实战篇】--PyTorch+Transformer谣言检测系统
任务:构建一个多模态谣言检测模型。 数据集描述如下: 数据集包含以下模态: 谣言文本:谣言的核心文本信息。2. 配图:与谣言文本相关的图像数据;3. OCR 文本:可以通过 PaddleOCR 从配图中提取的…...
PostGreSQL/openGauss表膨胀处理
如果面试官问你,Oracle与PG/OG最大的区别是什么?你要是没回答出MVCC机制,表膨胀,那你多半挂了。 在PG/OG数据库中,命令vacuum full,插件pg_repack用于处理表膨胀,但是别高兴得太早,如…...
视频融合平台EasyCVR搭建智慧粮仓系统:为粮仓管理赋能新优势
一、项目背景 当前粮仓管理大多仍处于原始人力监管或初步信息化监管阶段。部分地区虽采用了简单的传感监测设备,仍需大量人力的配合,这不仅难以全面监控粮仓复杂的环境,还容易出现管理 “盲区”,无法实现精细化的管理。而一套先进…...
基于 Node.js 和 Spring Boot 的 RSA 加密登录实践
在当今的互联网应用开发中,用户数据的安全性至关重要。登录功能作为用户进入系统的第一道防线,其安全性更是不容忽视。本文将介绍一种基于 RSA 加密的登录方案,前端使用 Node.js 的 node-forge 库对密码进行公钥加密,后端使用 Spr…...
jupyter在Pycharm中遇到的一个问题
jupyter比较简洁,可以分块执行,下面显示结果,还能用Markdown写注释,总体来说来还是比较好用的。 但是遇到了一个奇怪的问题,从一个py文件中导入一个函数,结果输出为None。但是如果直接把这个函数的内容复制…...
十二、buildroot系统 adb登录权限设置
4.6.4、adb权限设置 android-adbd 是 ADB(Android Debug Bridge)的守护进程,允许开发者远程访问和调试设备。它通常用于 Android 设备,但在嵌入式 Linux上,也可以用来提供远程 shell、文件传输和应用调试功能。 …...
MySQL、Oracle 和 PostgreSQL 是三种主流的关系型数据库的主要原理性差异分析
MySQL、Oracle 和 PostgreSQL 是三种主流的关系型数据库,它们在底层原理和设计哲学上存在显著差异,尤其在存储引擎、事务处理、并发控制、索引结构、复制机制等方面。以下是它们的主要原理性差异分析: 1. 存储引擎与架构设计 MySQL 多存储引…...
【AI开源大模型工具链ModelEngine】【01】应用框架-源码编译运行
ModelEngine提供从数据处理、知识生成,到模型微调和部署,以及RAG(Retrieval Augmented Generation)应用开发的AI训推全流程工具链。 GitCode开源地址:https://gitcode.com/ModelEngineGitee开源地址:https…...
一文掌握 google浏览器插件爬虫 的制作
更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 一、技术栈1. 前端技术(浏览器插件开发)2. 爬虫技术3. 后端(可选)4. 整体技术栈组成二、开发步骤1. 创建 Chrome 插件基础结构(1)`manifest.json` 配置(2)前端页面(`popup.html`)(3)前端逻辑(`popup.js`)…...
【leetcode 100】贪心Java版本
划分字母区间 题目 我的思路:第一次没有一点思路,第二次看了官网思路后,写的以下答案,没有搞明白循环遍历, //是不对的以下: class Solution {public List<Integer> partitionLabels(String s) {Li…...
Linux用Wireshark进行Thread网络抓包关键步骤
用Nordic nRF52840 Dongle作为RCP配合Wireshark进行Thread网络抓包是debug Thread网络的有效工具之一,主要流程在这里,不再赘述:官方流程 但是按官方流程会卡在一个地方,第一次费劲解决后,今天在另一台机器重新配的时…...
项目管理中客户拒绝签字验收?如何处理和预防
客户拒绝签字验收?如何处理和预防?核心在于:正面沟通、证据留存、灵活应对、合同条款明确、阶段验收机制。其中正面沟通格外关键,如果在发现客户迟迟不愿签字时能够主动沟通,了解其顾虑或不满并迅速针对性解决…...
docker 修改镜像源教程
当在拉取镜像时报以下错误时,可以通过更换镜像源解决 rootlocalhost:/etc/docker# docker pull mysql Using default tag: latest Error response from daemon: Get "https://registry-1.docker.io/v2/": net/http: request canceled while waiting for …...
【JAVA】十、基础知识“类和对象”干货分享~(三)
目录 1. 封装 1.1 封装的概念 1.2 访问限定符 public(公开访问) private(私有访问) 1.3 包 1.3.1 包的概念 1.3.2 导入包中的类 1.3.3 自定义包 2. static成员 2.1 static变量(类变量) 2.1.1 sta…...
Open GL ES -> SurfaceView + 自定义EGL实现OpenGL渲染框架
SurfaceView 自定义EGL实现OpenGL渲染 在Android开发中,当需要灵活控制OpenGL渲染或在多个Surface间共享EGL上下文时,自定义EGL环境是必要的选择 核心实现流程 -------------------- -------------------- -------------------- | 1. 创建Su…...
Solidity入门实战—web3
项目介绍 在这个项目中,我们建立一个小型智能合约应用,他允许用户向合约地址捐赠,允许合约所有者从合约中提取余额;并且还设定了捐赠的金额门槛;针对直接对地址进行的捐赠行为,我们也予以记录 源代码 ht…...