注册通行证 用户名 密码
  • 文章投稿
  • 博客
  • 论坛
  • 设为首页
  • 加入收藏
jztop.com网络技术
  • 首页
  • | iT新闻
  • | 操作系统
  • | 组网建网
  • | 网络安全
  • | 程序开发
  • | 办公一族
  • | 工具软件
  • | 网页制作
  • | 多媒体制作
  • | 网吧技术
  • | 服务器
  • | 专题教程
Vista | 软件评测 | 系统备份 | 优化 | 进程 | 聊天 | 病毒 | Linux | 黑客 | 防火墙 | 数据库 | Web开发 | Java | Word | 游戏 | 32位开发 | 移动开发
当前位置:首页 > 程序开发 > 数据库 > Delphi 内容正文:在DBGrid组件中显示和编辑MEMO字段

在DBGrid组件中显示和编辑MEMO字段

发布时间:2006-07-08 09:50:16 来源:天极开发 网友评论 0 条
  Delphi之所以能在.NET与JAVA“两座大山”重压之下,至今仍被广大编程爱好者喜爱、支持,究其原因,除了VCL框架设计精妙之外,强大的数据库程序开发能力也是其长盛不衰的关键因素之一。说到数据库开发不能不提到DELPHI中自带的功能强劲的数据感知组件,这些组件中最为常用的当属DBGrid组件,这个组件提供了二维表的数据显示方式,一次提供的信息量大、结构鲜明、一目了然。虽然它有这么多优点,然而“没有银弹”(其大意为没有一种形式可以解决所有的问题)这句IT界中人所共知的箴言又开始应验了,它有不少缺点,其中一个就是:当你开发一个数据库应用程序时,如果所用的数据表中带有MEMO(备注类型)的字段,你会注意到,在DBGrid的缺省显示方式下,这种类型的字段将显示成“(MEMO)”的形式(如图1所示)。MEMO字段类型中数据表中的主要功能是存放相对比较大数量的文本或是文本与数字的结合,在大多数数据库中这种类型的数据有规定的数量上的限定。


  只能显示“(MEMO)”这种形式显然不能够满足用户的需要,为了能够使得数据被实际显示出来,我们需要写一些代码,对DBGrid做一点功能上的增强。首先,我们要先在数据库中建立一张表,命名为TestTable,这张表中至少要有一个MEMO类型的字段,把它命名为Data。然后我们来给字段的OnGetText事件写一段代码实现上面的需求。操作步骤如下:

  1. 把你的TDataset组件与刚才新建的数据库中的TestTable表相连接。

  2. 双击TDataset组件来打开字段编辑器(Fields editor)。

  3. 添加MEMO字段Data.

  4. 选中该字段,在对象检查器中(Object Inspector)双击OnGetText事件建立事件句柄。

  编写代码如下:

procedure TForm1.DBTableDataGetText(Sender: TField;
var Text: String;
DisplayText: Boolean);
begin
Text := Copy(DBTableData.AsString, 1, 50);
end;

  TDataset对象的名字是“DBTable”,MEMO字段的名字是“Data”,因此缺省情况下连接到MEMO字段的TMEMOField名字是“DBTableData”。我们在代码中告诉DBGrid将MEMO字段显示成文本方式,就是把实际的内容显示出来。这里有一个值得注意的地方,因为MEMO字段可以容纳比较多的文本,在DBGrid中全部显示出来的话,DBGrid就会被撑得很大,所以我们做了限制,只是把MEMO中的前50个字符显示出来。(如图2)


  显示的工作完成之后,我们还想对显示出来的文本进行编辑,这在缺省状态下是不可以实现的,我们准备另建一个窗体,在上面放置一个DBMemo组件,用它来对文本进行编辑,思考到这里还有一个需要解决的问题,如何来触发一次编辑过程呢?就用键盘的回车键吧,当记录指针指向这条记录时,按下回车键,则弹出一个窗体,上面的DBMemo组件可以显示并且编辑文本。实现代码如下:

procedure TForm1.DBGrid1KeyDown(
 Sender: TObject;
 var Key: Word;
 Shift: TShiftState);
 begin
  //如果按下的是回车键则触发下面的代码
  if Key = VK_RETURN then
  begin
   if DBGrid1.SelectedField = DBTableData then
    //建立新的窗体
    with TMemoEditorForm.Create(nil) do
    try
     //读取数据库中的数据用DBMemo来显示
     DBMemoEditor.Text := DBTableData.AsString;
     ShowModal;
     DBTable.Edit;
     DBTableData.AsString := DBMemoEditor.Text;
    finally
     Free;
    end;
  end;
 end;

  上面的步骤实现之后,实际的程序运行效果是这样的(如图3)。


  动动你的脑筋、理清思路、列出算法,很多知名软件中的很酷功能我们都能够来实现,各位读者月友,打开DELPHI,体验一下吧。
相关文章
    无相关信息
【评论】【收藏本文】【打印】【关闭】
上一篇文章:用DELPHI在状态栏中显示进程条
下一篇文章:在Delphi中应用AOP实现日志功能
讨论区
查看
已有 0 位对此新闻感兴趣的网友发表了看法
匿名发表
注册通行证 登陆
图文阅读推荐
推荐阅讯
  • 5天玩转NoahWeb逻辑层--第5天
  • 将视频演示作为应用程序的启动封面
  • VFP9.0中设计与使用表单和报表
  • Ajax在.NET中与Server控件的交互
  • Delphi.NET多层应用系统开发技术研讨
  • 5天玩转NoahWeb逻辑层--第4天
  • 破解高手常用的破解工具介绍
  • 解密宝典——十招教你学会软件破解
  • 系统构架设计应考虑的因素
  • 程序界面设计模式慨述
阅读排行
  • 1.全面剖析Delphi 2006新增特性
  • 2.用Delphi开发视频聊天软件
  • 3.用Win32 API枚举应用程序窗口和进程
  • 4.软件的架构与设计模式之什么是架构
  • 5.软件的架构与设计模式之模式的种类
  • 6.Delphi中为TreeView添加单选和复选框
  • 7.用Delphi实现24位真彩色图标
  • 8.VS.NET2005 Beta2初体验之感受2005
  • 9.程序界面设计模式慨述
  • 10.没落的奇迹 谁会买下Delphi?
专题教程
  • 大话G游 专题:手机病毒揭密
  • ARP攻击防范与解决方案 路由故障处理手册
  • Picasa中文版_Picasa教程 专题:清除流氓软件
  • Firefox专题 seo搜索引擎优化专区
  • 重装Windows必知的事情 装机之必备软件大行动
病毒专杀栏
  • 杀毒软件反被病毒杀 连"救命"都不能喊
  • 金山ARP防火墙
  • 还原卡神话破灭“机器狗”病毒来势汹汹
  • cctv经济半小时:你的手机现在安全吗?
  • 新挂马方式开始流行 ARP挂马称雄局域网
  • 木马和病毒清除的通用解法
  • IP地址不再冲突 查找ARP攻击者元凶
  • 教你几招识别和防御Web网页木马
  • 分析:封杀BT只是暂时的止痛药
  • QQ爆危险漏洞,“QQ游戏邀请大盗”邀请你玩病
关于我们 | 诚聘英才 | 联系我们 | 版权声明 | 网站大事 | 网站地图 | 意见建议
CopyRight 2005-2007 Jztop.Com 版权所有 未经许可 请勿转载