ODBC 错误"String data, right truncation State code: 22001"与 SQL Server 数据库



我有一个使用Microsoft SQL Server的测试表,其定义如下:

CREATE TABLE [dbo].[Table] ( [FirstName] NVARCHAR (255) NULL, [LastName] NVARCHAR (255) NULL );

表中只有一行的值分别为"person"one_answers"man"。

我试图添加一个函数来更新该行的值,但我一直遇到这个"[Microsoft][ODBC SQL Server Driver]字符串数据,右截断状态代码:22001"错误,我不知道问题出在哪里。我环顾四周,人们说这是由于数据太长而无法放入列中造成的,但这是不可能的,因为我试图更新的字符串只有两个字符,正如你在表定义中看到的那样,它有足够的空间。

我使用一个准备好的语句进行优化,创建它的代码看起来像这样:

const tString query("UPDATE "" + tableName + "" SET " + setClause + " WHERE " + whereClause + ";");
SQLHSTMT statement;
SQLAllocHandle(SQL_HANDLE_STMT, fSQLConnection, &statement);
SQLPrepareW(statement, (SQLWCHAR *) query.mWideStr(), SQL_NTS);`

查询字符串如下所示:

UPDATE "Table" SET "FirstName" = ?, "LastName" = ? WHERE "FirstName" = ? AND "LastName" = ?;

然后我绑定这样的参数:

// We have our own string class that we use, which is where the mWideStr() and mGetStrSize()
// come from. mWideStr() returns a pointer to a UCS-2 buffer and mGetStrSize() returns the
// size in bytes.
SQLLEN pcbValue(SQL_NTS);
SQLUSMALLINT paramIndex(1);
// Call this for each parameter in the correct order they need to be bound, incrementing the
// index each time.
SQLBindParameter(statement, paramIndex++, SQL_PARAM_INPUT, SQL_C_WCHAR, SQL_VARCHAR, 255, 0, (SQLPOINTER) paramValue.mWideStr(), paramValue.mGetStrSize(), &pcbValue);

第一个和第二个界限参数是新的值,都只有"55",然后第三个是"人",第四个是"男人"。

然后要执行这些语句,只需调用SQLExecute():

SQLExecute(statement);

SQLExecute()的调用失败,然后生成错误,并且还有一些代码输出错误消息。据我所知,这一切应该都很顺利。我有另一个使用Oracle的数据库,它使用了完全相同的设置和代码,它工作起来没有任何问题,只是SQL Server因为某种原因而出现了问题。我是不是遗漏了什么明显的问题?SQL Server是否有一些奇怪的规则需要添加?

传递给SQLBindParameter()SQLLEN pcbValue(SQL_NTS);变量在绑定参数和执行语句之间超出了范围,这意味着在参数绑定中指向了一些垃圾数据。我还意识到,您不需要指定最后一个参数。您可以直接传递NULL,它将表现为一个以nul结尾的字符串。

因此,修复方法是删除SQLLEN pcbValue(SQL_NTS);变量,并将NULL传递给SQLBindParameter()作为最后一个参数。

愚蠢的错误,但我想值得注意。

最新更新