SQLBindParameter用于输出varchar
SQLBindParameter for output varchar
我有一个具有varchar
输出参数的存储过程:
@UserIDOut varchar(50) OUTPUT
在我的c++代码中,我尝试将输出参数绑定到this:
...
SQLCHAR userIDOut[50];
int dbReturn = ExecProc(...(SQLCHAR**)&userIDOut);
...
int ExecProc(...SQLCHAR **userIDOut)
{
...
SQLINTEGER cbParam7 = SQL_NTS;
retcode = SQLBindParameter(hstmt1, 7, SQL_PARAM_OUTPUT, SQL_C_CHAR, SQL_VARCHAR, 50, 0, *userIDOut, 50, &cbParam7);
retcode = SQLExecDirect(hstmt1, (UCHAR*)"{? = call UpdateUser(?,?,?,?,?,?)}", SQL_NTS);
我还有其他几个输入参数,以及这个存储过程的一个返回值。我已经尝试了这个函数调用的一些变化,但我从来没有得到任何在userIDOut
。如果我从SQL Server执行存储过程,我将得到正确的输出。
任何想法吗?
根据注释:
需要将指向userIDOut
的指针传递给SQLBindParameter
。你传递的不是一个指向userIDOut
的指针,而是userIDOut
的第一个字节被重新解释为一个指针。
数组隐式地转换为指向其第一个元素的指针(并且由于数组连续存储在内存中,这使得其他数据也可以访问),因此不需要写&userIDOut
,如果将类型更改为SQLCHAR *
,则只需写userIDOut
。
int ExecProc(..., SQLCHAR *userIDOut)
{
...
... SQLBindParameter(..., userIDOut, 50, &cbParam7);
...
}
// To call
... ExecProc(..., userIDOut);
如果您愿意,您可以继续使用指向userIDOut
的指针,但这要求您使用指向数组的指针,而不是指向指针的指针,并且指向数组的指针使用一种尴尬的语法,并且通常没有比指向数组元素的指针更多的值:
int ExecProc(..., SQLCHAR (*userIDOut)[50])
{
...
... SQLBindParameter(..., userIDOut, 50, &cbParam7);
...
}
// To call
... ExecProc(..., &userIDOut);
相关文章:
- 递归函数计算序列中的平方和(并输出过程)
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 请解释"函数1(p1,p2,p3);"的输出
- C++:将控制台输出存储在宏中更好吗
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 为什么我的代码在输出中增加了93天
- 如何从void函数输出字符串
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- AES加密到解密未正确输出
- 如何将c++程序的一些输出传递给shell,以便在shell中使用
- 使用C++程序合并排序没有得到正确的输出
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- C++格式化输出问题
- 将值从二维数组输出到文本文件
- 集合上的输出迭代器:assign和increment迭代器
- 在while循环中输入带有std::cin的字符串后,控制台会输出大量胡言乱语
- 为什么rk4.do_step不输出C++中的初始条件
- 如何将QString绑定到QSQLQUERY,该呼叫过程输出VARCHAR
- SQLBindParameter用于输出varchar