从 SQL 到 C:日期时间间隔
日时间间隔 ODBC SQL 数据类型的标识符如下:
- SQL_INTERVAL_DAY
- SQL_INTERVAL_DAY_TO_MINUTE
- SQL_INTERVAL_HOUR
- SQL_INTERVAL_DAY_TO_SECOND
- SQL_INTERVAL_MINUTE
- SQL_INTERVAL_HOUR_TO_MINUTE
- SQL_INTERVAL_SECOND
- SQL_INTERVAL_HOUR_TO_SECOND
- SQL_INTERVAL_DAY_TO_HOUR
- SQL_INTERVAL_MINUTE_TO_SECOND
下表显示了可将 SQL 数据转换为日时间间隔的 ODBC C 数据类型。 有关表中的列和术语的说明,请参阅 将数据从 SQL 转换为 C 数据类型。
C 类型标识符 | 测试 | * TargetValuePtr | * StrLen_or_IndPtr | SQLSTATE |
---|---|---|---|---|
所有日间 C 间隔类型 | 尾随字段部分未截断 尾随字段部分截断 目标前导精度不足以保存源中的数据 |
数据 截断的数据 Undefined |
数据长度 数据长度 Undefined |
不适用 01S07 22015 |
SQL_C_STINYINT[b] SQL_C_UTINYINT[b] SQL_C_USHORT[b] SQL_C_SHORT[b] SQL_C_SLONG[b] SQL_C_ULONG[b] SQL_C_NUMERIC[b] SQL_C_BIGINT[b] | 间隔精度为单个字段,转换数据时未截断 间隔精度为单个字段,截断了小数部分 间隔精度是单个字段,截断了整个 间隔精度不是单个字段 |
数据 截断的数据 截断的数据 Undefined |
C 数据类型的大小 数据长度 数据长度 C 数据类型的大小 |
不适用 01S07 22003 07006 |
SQL_C_BINARY | 数据的 <字节长度 = BufferLength 数据 >BufferLength 的字节长度 |
数据 Undefined |
数据长度 Undefined |
不适用 22003 |
SQL_C_CHAR | 字符字节长度 <BufferLength 整 (数,而不是小数) 位数 <BufferLength 与小数) 位数 >相比,整个 (数 = BufferLength |
数据 截断的数据 Undefined |
C 数据类型的大小 C 数据类型的大小 Undefined |
不适用 01004 22003 |
SQL_C_WCHAR | 字符长度 <BufferLength 整 (数,而不是小数) 位数 <BufferLength 与小数) 位数 >相比,整个 (数 = BufferLength |
数据 截断的数据 Undefined |
C 数据类型的大小 C 数据类型的大小 Undefined |
不适用 01004 22003 |
[a] 日时间间隔 SQL 类型可以转换为任何日时间间隔 C 类型。
[b] 如果间隔精度是 (DAY、HOUR、MINUTE 或 SECOND) 之一的单个字段,则可以将间隔 SQL 类型转换为任何精确的数值 (SQL_C_STINYINT、SQL_C_UTINYINT、SQL_C_USHORT、SQL_C_SHORT、SQL_C_SLONG、SQL_C_ULONG或SQL_C_NUMERIC) 。
间隔 SQL 类型的默认转换是到相应的 C 间隔数据类型。 然后,应用程序 (绑定列或参数,或设置 ARD) 适当记录中的SQL_DESC_DATA_PTR字段,以指向初始化的 SQL_INTERVAL_STRUCT 结构 (,或在调用 SQLGetData) 时将指向 SQL_ INTERVAL_STRUCT 结构的指针作为 TargetValuePtr 参数传递。
以下示例演示如何将数据从类型为 SQL_INTERVAL_DAY_TO_MINUTE 的列传输到 SQL_INTERVAL_STRUCT 结构,以便以DAY_TO_HOUR间隔返回。
SQL_INTERVAL_STRUCT is;
SQLINTEGER cbValue;
SQLUINTEGER days, hours;
// Execute a select statement; "interval_column" is a column
// whose data type is SQL_INTERVAL_DAY_TO_MINUTE.
SQLExecDirect(hstmt, "SELECT interval_column FROM table", SQL_NTS);
// Bind
SQLBindCol(hstmt, 1, SQL_C_INTERVAL_DAY_TO_MINUTE, &is, sizeof(SQL_INTERVAL_STRUCT), &cbValue);
// Fetch
SQLFetch(hstmt);
// Process data
days = is.intval.day_second.day;
hours = is.intval.day_second.hour;