gpt4 book ai didi

oracle - 使用 TADOQuery 转换负数

转载 作者:行者123 更新时间:2023-12-03 15:36:28 28 4
gpt4 key购买 nike

我在 TADOQuery 方面遇到了一个大问题:

这是我的 SQL:

select cast(-10 as number(9)) foo, -10 bar 
from dual

当您添加“foo”字段时,将创建一个 TIntegerField,而不是 TBCDField,因为此时类型已更改:

procedure TCustomADODataSet.InternalInitFieldDefs;

if (F.Type_ = adNumeric) and (F.NumericScale = 0) and
(F.Precision < 10) then
FieldType := ftInteger;

功能:

function TCustomADODataSet.GetFieldData(Field: TField; Buffer: Pointer;
NativeFormat: Boolean): Boolean;

此时不考虑信号:

    ftAutoInc, ftInteger:
Integer(Buffer^) := lVal;

TIntegerField 的 tagVariant 值为:

(14, 32768, 0, 0, 10, 10, 10, 1.4012984643e-44, 4.9406564584e-323, 真, 10, 0.001, 4.9406564584e-323, , $A, $A, $A, $ A、$A、$A、$A、$A、$A、$A、$A、$A、$A ''、$A、$A、$A、$A、$A、#10、10 , 10, 10, 10, $A, , $A, $A, $A, $A)

这与 TBCDField 相同:

(14, 32768, 0, 0, 10, 10, 10, 1.4012984643e-44, 4.9406564584e-323, 真, 10, 0.001, 4.9406564584e-323, , $A, $A, $A, $ A、$A、$A、$A、$A、$A、$A、$A、$A、$A ''、$A、$A、$A、$A、$A、#10、10 , 10, 10, 10, $A, , $A, $A, $A, $A)

foo 值为 10,bar 值为 -10。

这是一个错误吗?
有解决方法吗?
修好了?

我使用 Microsoft OLEDB Provider for Oracle 和 Oracle Provider for OLEDB 进行了测试。所有测试均使用Delphi 6完成。

最佳答案

我不知道我是否理解正确,但是尝试这样:

select cast(replace(-10,'-','') as number(9)) foo, -10 bar 
from dual;

关于oracle - 使用 TADOQuery 转换负数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16199517/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com