gpt4 book ai didi

c++ - 通过 ODBC C++ 将带有日期时间的记录插入 SQL Server 2014 的问题

转载 作者:太空宇宙 更新时间:2023-11-04 12:52:31 24 4
gpt4 key购买 nike

我有一个简单的 C++ 代码,可以通过 ODBC 在 SQL Server 2014 中插入一条记录。它适用于 varchar 字段,但不适用于 datetime 字段。

SQLCHAR buf[64];
SQLLEN len;
SQLCHAR buf2[255];
SQLLEN len2;
SQLLEN len3;
double f;
rc = SQLBindParameter(hstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_TYPE_TIMESTAMP, 19, 0, (SQLCHAR*)buf, 0, &len);
rc = SQLBindParameter(hstmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_VARCHAR, 255, 0, (SQLCHAR*)buf2, 0, &len2);
rc = SQLBindParameter(hstmt, 3, SQL_PARAM_INPUT, SQL_C_FLOAT, SQL_FLOAT, 15, 0, &f, 0, &len3);
rc = SQLPrepare(hstmt, (SQLCHAR*)"insert into test(timepoint,strvalue,floatvalue) values (?,?,?)", SQL_NTS);

strcpy((char*)buf,"20171010 00:08:14");
len=strlen("20171017 00:08:14");
strcpy((char*)buf2,"simple string");
len2=strlen("simple string");
f=1.34e+8;

SQLSMALLINT NumParams;
SQLNumParams(hstmt, &NumParams);
rc = SQLExecute(hstmt);

任何人都可以帮助理解这是错误的吗?我总是:

“22018:1:0:[Microsoft][ODBC SQL Server 驱动程序]转换规范的字符值无效\n”

如果我的问题在这里有误,请提示哪个论坛更合适。我花了几天时间,但找不到解决方案。如有任何帮助,我们将不胜感激。

最佳答案

SQL Server 可以将不同日期格式的各种字符串隐式转换为真实日期,但您必须非常小心地使用它们:

不分隔日期格式“yyyyMMdd”,不能携带时间!

SELECT CAST('20170102' AS DATETIME) --2017-01-02 00:00:00.000

最通用的格式是 ISO8601,即 yyyy-MM-ddTHH:mm:ss(注意 T中间和24小时格式的使用!)

SELECT CAST('2017-01-02T12:23:59' AS DATETIME) --2017-01-02 12:23:59.000

最后但并非最不重要的一点是,共有三种 ODBC 格式:

SELECT CAST({d'2017-01-02'} AS DATETIME)           --2017-01-02 00:00:00.000
SELECT CAST({t'23:35:51'} AS DATETIME) --2018-01-19 23:35:51.000 (today!)
SELECT CAST({ts'2017-01-02 23:35:51'} AS DATETIME) --2017-01-02 23:35:51.000

还有最后一点——很重要! - 提示:某些格式有效,但取决于系统的设置。这可以为您工作并通过所有内部测试,但可能会在客户的机器上中断:

SET LANGUAGE ENGLISH;
SELECT CAST('2017-01-02 23:35:51' AS DATETIME) -- Jan 2
SET LANGUAGE GERMAN;
SELECT CAST('2017-01-02 23:35:51' AS DATETIME) -- Feb 1

关于c++ - 通过 ODBC C++ 将带有日期时间的记录插入 SQL Server 2014 的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48336773/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com