ADO的AsFloat返回的值有什么问题?

heinsect 2003-10-20 11:40:57
在表中定义两个字段为:
TEngMon_Absence float DEFAULT 1 NOT NULL ,
TEngMon_NormalOT float DEFAULT 1 NOT NULL ,

在SQL2K中查表看到是1.0

Delphi中代码:
m_dfAbsenceDay := ADOQuery1.FieldByName('TEngMon_Absence').AsFloat;
m_dfNormalOT:= ADOQuery1.FieldByName('TEngMon_NormalOT' ).AsFloat;

edAbsence.Text := FormatFloat('0.00', m_dfAbsenceDay);
edNormalOT.Text := FormatFloat('0.00', m_dfNormalOT);

edAbsence.Text赋值时没问题,edNormalOT.Text赋值时出EConvertError异常:
''' is not a valid floating point value'

我自己重写过FormatFloat,用Format,临时变量值正确,交给result就出错。
?????????
...全文
212 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
heinsect 2003-10-21
  • 打赏
  • 举报
回复
我改成了下面的样子,编译时关了优化,加上所有的调试。单步走,同样的异常:

ShowMessage(ADOQuery1.FieldByName('TEngMon_Absence' ).AsString);//显示结果为1
strTemp := ADOQuery1.FieldByName('TEngMon_Absence').AsString;
edAbsence.Text := strTemp;
m_dfAbsenceDay := StrToFloat(strTemp);

ShowMessage(ADOQuery1.FieldByName('TEngMon_NormalOT' ).AsString)//显示结果为1;
strTemp := ADOQuery1.FieldByName('TEngMon_NormalOT' ).AsString;
edNormalOT.Text := strTemp; <------------这一行报错
m_dfNormalOT := StrToFloat(strTemp);

我试的时候表中的定义用decimal(4,1)/numeric(4,1)/float都用过。都是同样的错。
fhuibo 2003-10-21
  • 打赏
  • 举报
回复
没有问题的
angle097113 2003-10-21
  • 打赏
  • 举报
回复
这样实现就可以了
edAbsence.Text := ADOQuery1.FieldByName('TEngMon_Absence').AsString;
edNormalOT.Text := ADOQuery1.FieldByName('TEngMon_NormalOT' ).AsString;
没有问题的!


pingo888 2003-10-21
  • 打赏
  • 举报
回复
edAbsence.Text := ADOQuery1.FieldByName('TEngMon_Absence').AsString;
edNormalOT.Text := ADOQuery1.FieldByName('TEngMon_NormalOT' ).AsString;
heinsect 2003-10-21
  • 打赏
  • 举报
回复
多谢zhyanger,就是OnChange与前面的代码捣乱。
edNormalOnChange:
m_dfNormalOT := StrToFloat(edNormalOT.Text);

我在所有控件的Text中加了一个初值,解决了。

这么说Delphi中的OnChange是在另一个线程中处理的,没想到这一点。
所以我跟踪时到不了这里。

多谢各位,再加100分。前面的100给zhyanger,另100大家分吧。
zhyanger 2003-10-21
  • 打赏
  • 举报
回复
你在edNormalOT.onchange内有事件吗(或者ADOQuery1有计算字段)?设断点跟踪一下,
dowsun 2003-10-21
  • 打赏
  • 举报
回复
如果看上去没有问题,可以用强制转换:
var
TpmStr : String;
TmpFloat : Float;
...

TmpStr := ADOQuery1.FieldByName('TEngMon_NormalOT' ).AsString;
TmpFloat := StrToFloat(TmpStr);
dowsun 2003-10-21
  • 打赏
  • 举报
回复
先让系统返回字符串,然后把它show一下,应该可以看出问题所在。

ShowMessage(ADOQuery1.FieldByName('TEngMon_NormalOT' ).AsString);
angle097113 2003-10-21
  • 打赏
  • 举报
回复
后来的提示什么错误呢?
我的代码:
Var
strTemp:String;
m_dfAbsenceDay:Double;
m_dfNormalOT:Double;
begin
ShowMessage(ADOQuery1.FieldByName('aa' ).AsString);
strTemp := ADOQuery1.FieldByName('aa').AsString;
Edit1.Text := strTemp;
m_dfAbsenceDay := StrToFloat(strTemp);
ShowMessage(ADOQuery1.FieldByName('f2' ).AsString);
strTemp := ADOQuery1.FieldByName('f2' ).AsString;
edit2.Text := strTemp;
m_dfNormalOT := StrToFloat(strTemp);
end;
aa,f2都是float字段类型的数据 我的没有问题的呀!再看看吧 希望我写的对于你有价值!
heinsect 2003-10-20
  • 打赏
  • 举报
回复
我自己顶
net的最近面试经典试题ASP.NET面试题集合 1. 简述 private、 protected、 public、 internal 修饰符的访问权限。 答 . private : 私有成员, 在类的内部才可以访问。 protected : 保护成员,该类内部和继承类中可以访问。 public : 公共成员,完全公开,没有访问限制。 internal: 在同一命名空间内可以访问。 2 .列举ASP.NET 页面之间传递的几种方式。 答. 1.使用QueryString, 如....?id=1; response. Redirect().... 2.使用Session变量 3.使用Server.Transfer 3. 一列数的规则如下: 1、1、2、3、5、8、13、21、34...... 求第30位数是多少, 用递归算法实现。 答:public class MainClass { public static void Main() { Console.WriteLine(Foo(30)); } public static int Foo(int i) { if (i 0 && i <= 2) return 1; else return Foo(i -1) + Foo(i - 2); } } 4.C#中的委托是什么?事件是不是一种委托? 答 : 委托可以把一个方法作为参数代入另一个方法。 委托可以理解为指向一个函数的引用。 是,是一种特殊的委托 5.override与重载的区别 答 : override 与重载的区别。重载是方法的名称相同。参数或参数类型不同,进行多次重载以适应不同的需要 Override 是进行基类中函数的重写。为了适应需要。 6.如果在一个B/S结构的系统中需要传递变量,但是又不能使用Session、Cookie、Application,您有几种方法进行处理? 答 : this.Server.Transfer 7.请编程遍历页面上所有TextBox控件并给它赋为string.Empty? 答: foreach (System.Windows.Forms.Control control in this.Controls) { if (control is System.Windows.Forms.TextBox) { System.Windows.Forms.TextBox tb = (System.Windows.Forms.TextBox)control ; tb.Text = String.Empty ; } } 8.请编程实现一个冒泡排序算法? 答: int [] array = new int ; int temp = 0 ; for (int i = 0 ; i < array.Length - 1 ; i++) { for (int j = i + 1 ; j < array.Length ; j++) { if (array[j] < array) { temp = array ; array = array[j] ; array[j] = temp ; } } } 9.描述一下C#中索引器的实现过程,是否只能根据数字进行索引? 答:不是。可以用任意类型。 10.求以下表达式的,写出您想到的一种或几种实现方法: 1-2+3-4+……+m [Page] 答: int Num = this.TextBox1.Text.ToString() ; int Sum = 0 ; for (int i = 0 ; i < Num + 1 ; i++) { if((i%2) == 1) { Sum += i ; } else { Sum = Sum - I ; } } System.Console.WriteLine(Sum.ToString()); System.Console.ReadLine() ; 11.用.net做B/S结构的系统,您是用几层结构来开发,每一层之间的关系以及为什么要这样分层? 答:一般为3层 数据访问层,业务层,表示层。 数据访问层对数据库进行增删查改。 业务层一般分为二层,业务表观层实现与表示层的沟通,业务规则层实现用户密码的安全等。 表示层为了与用户交互例如用户添加表单。 优点: 分工明确,条理清晰,易于调试,而且具有可扩展性。 缺点: 增加成本。 12.在下面的例子里 using Sy

2,496

社区成员

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

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