同一个存储过程,在桌面下正常,在web service下却出错?

kmfangxun 2007-04-06 02:16:22
同一个存储过程,在桌面下正常,在web service下却出错?

如下,其中strMemo为Text类型,数据库服务器为MS SqlServer2000。

出错提示:External exception EEFFACE

//------------------------------------------------------------------------
String sql= " Create Procedure GetMemoOfStudent "
" @Name varchar(100) as "
" select Name,strMemo from Student "
" Where =@Name ";

Query->Close();
Query->SQL->Text=sql;
Query->ExecSQL();


adoStoredProc->Close();
adoStoredProc->ProcedureName="GetMemoOfStudent";
adoStoredProc->Parameters->AddParameter();
adoStoredProc->Parameters->Items[0]->Name = "Name";
adoStoredProc->Parameters->Items[0]->DataType = ftString;
adoStoredProc->Parameters->Items[0]->Direction = pdInput;
adoStoredProc->Parameters->Items[0]->Value = "大刘";

String strMemo;
adoStoredProc->Prepared ;
adoStoredProc->Open();
strMemo=adoStoredProc->FieldByName("strMemo")->Value;
adoStoredProc->Close();
...全文
295 12 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
FFSB 2007-04-07
  • 打赏
  • 举报
回复
好的
adoStoredProc->Parameters->Items[0]->Value = Name;
try =>>adoStoredProc->Parameters->Items[0]->Value = WideString(Name);
kmfangxun 2007-04-07
  • 打赏
  • 举报
回复
to: FFSB()...()

adoStoredProc->Parameters->Items[0]->Value = WideString(Name);
=================================================================

试过了,同样的不行。

lurel 2007-04-06
  • 打赏
  • 举报
回复
关注一下,好久没碰BCB了。
kmfangxun 2007-04-06
  • 打赏
  • 举报
回复
to :FFSB()...()

不好意思,说错了,

应该在 adoStoredProc->Open()就出错了;所以adoStoredProc->RecordCount没法得知。
FFSB 2007-04-06
  • 打赏
  • 举报
回复
adoStoredProc->RecCount是多少
kmfangxun 2007-04-06
  • 打赏
  • 举报
回复
to :FFSB()...()


应该不是这个问题,调试时出错在

strMemo=adoStoredProc->FieldByName("strMemo")->Value; //strMemo为备注字段Text

经测试,即使把strMemo改为VarChar字段,同样也不行。


FFSB 2007-04-06
  • 打赏
  • 举报
回复
adoStoredProc->Parameters->Items[0]->Value = Name;
try =>>adoStoredProc->Parameters->Items[0]->Value = WideString(Name);
CEdward 2007-04-06
  • 打赏
  • 举报
回复
String strMemo;
...
return strMemo;

是不是这样return在函数内声名的字段有问题?
kmfangxun 2007-04-06
  • 打赏
  • 举报
回复
To: CEdward(桃树叶)

数据库都相同(Sql Server2000),表为:Student,比如有字段:id ,Name,strMemo;

建一个存储过程:
" Create Procedure GetMemoOfStudent "
" @Name varchar(100) as "
" select Name,strMemo from Student "
" Where Name=@Name ";


在桌面应用程序中一切正常:
void __fastcall TfrmClient::btnGetMemoClick(TObject *Sender)
{
adoStoredProc->Close();
adoStoredProc->ProcedureName="GetMemoOfStudent";
adoStoredProc->Parameters->AddParameter();
adoStoredProc->Parameters->Items[0]->Name = "Name";
adoStoredProc->Parameters->Items[0]->DataType = ftString;
adoStoredProc->Parameters->Items[0]->Direction = pdInput;
adoStoredProc->Parameters->Items[0]->Value = "大刘";

String strMemo;
adoStoredProc->Prepared ;
adoStoredProc->Open();
strMemo=adoStoredProc->FieldByName("strMemo")->Value;
adoStoredProc->Close();
ShowMessage(strMemo);
}

//建一个Web service,在Web服务程序的接口中,建一个接口的函数如下,那么在客户端调用该函数时出错,出错提示:External exception EEFFACE

String STDMETHODCALLTYPE TWebSrv::GetMemoOfStudent(String Name)
{
adoStoredProc->Close();
adoStoredProc->ProcedureName="GetMemoOfStudent";
adoStoredProc->Parameters->AddParameter();
adoStoredProc->Parameters->Items[0]->Name = "Name";
adoStoredProc->Parameters->Items[0]->DataType = ftString;
adoStoredProc->Parameters->Items[0]->Direction = pdInput;
adoStoredProc->Parameters->Items[0]->Value = Name;

String strMemo;
adoStoredProc->Prepared ;
adoStoredProc->Open();
strMemo=adoStoredProc->FieldByName("strMemo")->Value;
adoStoredProc->Close();

return strMemo;

}


CEdward 2007-04-06
  • 打赏
  • 举报
回复
Web Service 下出什么错,有什么出错信息?
在两个程序下的调用方式都相同吗?数据库都相同吗?
你给的信息太少了。
constantine 2007-04-06
  • 打赏
  • 举报
回复
不懂,路过一下
Red_angelX 2007-04-06
  • 打赏
  • 举报
回复
怪异 帮顶
资源下载链接为: https://pan.quark.cn/s/1bfadf00ae14 松下电工数字压力传感器用户手册详细介绍了DP-100系列数字压力传感器,涵盖其技术参数、操作方法及适用场景等,适用于各类需要精准压力测量的工业环境。 双屏显示:主屏与输出动作同步,可同时显示当前值和基准值,便于实时监控与调整。显示屏为12段字母数字显示,数字清晰易读。 三色指示:屏幕颜色随传感器状态变化(红、绿、橙),便于快速判断工作状态。 紧凑结构:尺寸仅□30mm,适合空间狭窄的安装环境。 多种操作模式:提供RUN模式(日常操作)、菜单设定模式(深入设置如输出模式切换)及PRO模式(高级功能如应差调整、复制设定)。 安全认证:DP-101(A)/102(A)型号通过特定认证,确保产品安全可靠。 复制功能:可通过数据通信将主传感器设定内容复制到其他传感器,减少人工设定错误,节省时间。 高性能传感:具备高精度,分辨率1/2,000,反应时间2.5ms(最长5,000ms可调),温度特性±0.5%F.S.,重复精度±0.1%F.S. 电子元件吸附检测:监测吸盘是否成功吸附电子元件。 总压力监测:测量管道或容器内的压力水平。 空气泄漏检测:通过压力变化检测泄漏情况。 DP-101□:适用于低压环境(-100kPa至100kPa)。 DP-102□:适用于高压环境(0kPa至1MPa)。 订购时需根据实际需求选择合适型号,考虑传感器的适用范围和工作条件。手册提供详细订购流程及注意事项,包括相关认证信息(如韩国S标志)。 复制功能:通过数据通信将主传感器设定复制到其他传感器,支持多种设定模式,避免设定错误,节省时间。 操作模式:RUN模式用于日常监控,菜单设定模式用于深入设置,PRO模式提供高级功能。 使用前需仔细阅读手册,了解各功能使用方法。遵循安全指南,正确安装和使用传感器,避免损坏。对于

1,178

社区成员

发帖
与我相关
我的任务
社区描述
C++ Builder 数据库及相关技术
社区管理员
  • 数据库及相关技术社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧