码迷,mamicode.com
首页 > 数据库 > 详细

Delphi 在dbgrideh中表格输入数据时有效性的检查(转)

时间:2019-03-22 18:55:02      阅读:187      评论:0      收藏:0      [点我收藏+]

标签:text   范围   tab   raise   表格   phi   pos   合法性   procedure   

在数据库系统设计中经常要用到在表格中进行数据录入,如何判断在数据导入时的数据有效性呢?下面介绍几种常用的方法与大家交流。

方法一:Dbgrid是与Table,在Table的Column的OnSetText和OnValidate事件中处理。 
1、在OnSetText中判断数据的合法性,如果不合法,在OnValidate处理,如果不合法则abort

2、抛出一个异常Raise,即可保证焦点不会丢失。


也可以在Table1.BeforePost里面处理,如果不符合要求,ShowMessage(""),然后Abort;


方法二:如果是Adoquery ,在Column的OnSetText和OnValidate事件中处理。 
在OnValidate处理,如果不合法则abort。

procedure Tfrm_cginput.q_maind_dateValidate(Sender: TField);

begin
if Sender.FieldName=‘d_date‘ then
if (Sender.AsDateTime>_DEnddate) or (Sender.AsDateTime<_DStartdate) then
begin
showmessage(‘日期超出范围‘);
abort;
end;
end;


方法三:


可以用DBGrid1ColExit事件进行。 
procedure TForm1.DBGrid1ColExit(Sender: TObject); 
begin 
case DBGrid1.SelectedIndex of 
0:if DBGrid1.DataSource.DataSet.Fields[0].value<>‘我想要的值‘ then 
于吗于吗。 
1: 
.. 
end; 
end;

Delphi 在dbgrideh中表格输入数据时有效性的检查(转)

标签:text   范围   tab   raise   表格   phi   pos   合法性   procedure   

原文地址:https://www.cnblogs.com/jijm123/p/10579923.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!