Devilchen 2017-03-27 02:18
浏览 669

SqlServer中数值参数传递后不正确的问题

ALTER PROCEDURE up_LeaveSendCostInputByPrince
@inoarray VARCHAR(6000),@quotename VARCHAR(50),@sendprice NUMERIC(18,2),@lowsendcost NUMERIC(18,2),@note VARCHAR(2000),@uid VARCHAR(15)
有这样一个问题,调用存储过程时,@sendprice,@lowsendcost ,如果传的参数是小于0.1,接收到的参数会乘以100,如传0.02,接收到的参数,就是2,但传0.2,就是正常的;如果参数定义改为NUMERIC(18,3),即3位小数,就会乘以100, with TempProc do
begin
Close;
ProcedureName:='up_LeaveSendCostInputByPrince';
Parameters.Refresh;
Parameters.ParamValues['@inoarray']:=inoarray;
Parameters.ParamValues['@quotename']:=Trim(CbQuote.Text);
Parameters.ParamValues['@sendprice']:=EdtSendPrice.Value;
Parameters.ParamValues['@lowsendcost']:=EdtLowSendCost.Value;
Parameters.ParamValues['@note']:=Trim(EdtNote.Text);
Parameters.ParamValues['@uid']:=Trim(MainFrm.CUid);
showmessage显示的值是正常的,只是用SqlServer Profiler跟踪到的值变了
调用环境是Delphi7

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
    • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
    • ¥20 有关区间dp的问题求解
    • ¥15 多电路系统共用电源的串扰问题
    • ¥15 slam rangenet++配置
    • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
    • ¥15 ubuntu子系统密码忘记
    • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
    • ¥15 保护模式-系统加载-段寄存器
    • ¥15 电脑桌面设定一个区域禁止鼠标操作