首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对于SQLCHAR类型参数,ODBC SQLBindParameter的ColumnSize参数可以是strlen(param) +1吗?

对于SQLCHAR类型参数,ODBC SQLBindParameter的ColumnSize参数可以是strlen(param) +1吗?
EN

Stack Overflow用户
提问于 2011-04-12 22:19:05
回答 1查看 1.5K关注 0票数 2

当C类型为SQL_C_CHAR时,http://msdn.microsoft.com/en-us/library/ms710963(v=vs.85).aspx上的SQLBindParameter函数的示例将字符数组的大小作为ColumnSize参数(第6个参数)传递。

引用该页面中的部分示例:

代码语言:javascript
复制
SQLCHAR szEmployeeID[EMPLOYEE_ID_LEN];
SQL_DATE_STRUCT dsOrderDate;
SQLINTEGER cbCustID = 0, cbOrderDate = 0, cbEmployeeID = SQL_NTS;

..。

代码语言:javascript
复制
retcode = SQLBindParameter(hstmt, 1, SQL_PARAM_INPUT,
                           SQL_C_CHAR, SQL_CHAR, EMPLOYEE_ID_LEN,
                           0, szEmployeeID, 0, &cbEmployeeID);

我想知道是否可以将字符串参数的长度加1作为ColumnSize参数。换句话说,如果我们假设szEmployeeID包含一个以null结尾的字符串,我想知道下面的调用是否正确。

代码语言:javascript
复制
retcode = SQLBindParameter(hstmt, 1, SQL_PARAM_INPUT,
                           SQL_C_CHAR, SQL_CHAR, strlen(szEmployeeID) + 1,
                           0, szEmployeeID, 0, &cbEmployeeID);

我相信这在这样的调用中非常有用:

代码语言:javascript
复制
SQLLEN nts = SQL_NTS;
retcode = SQLBindParameter(hstmt, 1, SQL_PARAM_INPUT,
                           SQL_C_CHAR, SQL_CHAR, 6,
                           0, "hello", 0, &nts);

char *domain = "stackoverflow.com";
retcode = SQLBindParameter(hstmt, 1, SQL_PARAM_INPUT,
                           SQL_C_CHAR, SQL_CHAR, strlen(domain) + 1,
                           0, domain, 0, &nts);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-10-10 05:22:26

这个问题的答案是“是”。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5636712

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档