TField中的GetText和SetText

在数据表中的某些字段出于性能或数据规范化的考虑,会用组编号代替,就像学生有学号,员工有员工ID一样,但我们看的时候如果直接输入这样的编号看的人可能就会头痛了,这时就可用TField中的GetText转成我们方便看的信息(其中可能涉及查表的操作,如根据学号从学生信息表(如果有)中获取姓名)。SetText完成相反过程。

如下图的SEX字段实际上是NUMBER类型。

***************************************************************************************

主要操作:

***************************************************************************************

DBGrid1.DataSource->DataSource1.DataSet->ClientDataSet1.ProviderName->DataSetProvider1.DataSet->

SQLDataset1.SQLConnection->SQLConnection1具体数据库(这里连接的是oracle中的PERSONS表);

SQLDataSet1.CommandText:=SELECT * PERSONS;ClientDataSet1.Active:=true;

DBNavigator1.DataSource->DataSource1。

*************************************************************************************

主要代码:

*************************************************************************************

procedure TForm4.ClientDataSet1SEXGetText(Sender: TField; var Text: string;
  DisplayText: Boolean);
begin
   //可以使用查表操作这里没必要,非0表示男,0表示女
   if Sender.Value<>0 then
    begin
      Text:='';
    end else
    begin
      Text:='';
    end;
end;

procedure TForm4.ClientDataSet1SEXSetText(Sender: TField; const Text: string);
begin
   //可以使用查表操作这里没必要
   if Text='' then
   begin
      Sender.Value:=1;
   end else
   begin
      Sender.Value:=0;
   end;
end;

procedure TForm4.FormCreate(Sender: TObject);
begin
   //连接事件
   ClientDataSet1SEX.OnGetText:=ClientDataSet1SEXGetText;
   ClientDataSet1SEX.OnSetText:=ClientDataSet1SEXSetText;
   //这里是添加SEX字段的下拉选择选项
   DBGriD1.Columns[4].PickList.DelimitedText:='男,女';
end;

对象检视器中连接事件:

对象检视器中添加下拉选项:

转载于:https://www.cnblogs.com/sun998/p/6515323.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值