用C语言操作SQLserver数据库的一个奇怪现象
来源:优易学  2010-1-14 11:45:09   【优易学:中国教育考试门户网】   资料下载   IT书店
  用C语言操作数据库时,已经成功连接并能够读写。代码中有如下一段内容:
  command = "INSERT into D31FATTR (D31ID, D31AB00) values (";
  command = command + fileid_str;
  command = command + ",'";
  command = command + autoAbs->abstractBuf;
  command = command +"') ";
  rc=SQLExecDirect(whstmt,(SQLCHAR *)command.c_str(),SQL_NTS);
  其中command的数据类型为string,fileid_str和autoAbs->abstractBuf的数据类型都都是char *,此时一切正常。我又在这段代码之后加入了以下内容:
  command = "INSERT into D31FILES (D31ID, D31FT, D31HT) values (";
  command = command + fileid_str;
  command = command + ",'";
  command = command + (char *)title;
  command = command +"','";
  command = command + (char *)content);
  command = command + "')";
  rc=SQLExecDirect(whstmt,(SQLCHAR *)command.c_str(),SQL_NTS);
  其中title和content的数据类型都为unsigned char *,
  看起来与上面代码没有什么本质区别,编译后,在执行到这段代码之前的与数据库建立连接时就失败了。
  开始时我怀疑是强制类型转换造成的,为了找出原因,我把所有后加入的这段代码先全部注释掉,然后每次添加一条语句重新编译执行,发现在加入第三条语句后就已经无法连接数据库了。
  我实在想不通是什么原因,工作被卡在了这里。希望有高人出手相助,我将感激不尽。

责任编辑:cyth

文章搜索:
 相关文章
热点资讯
资讯快报
热门课程培训