


全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Delphi在DBGrid组件中显示和编辑MEMO字段时间:2007-10-15 天极 小刀轻舞 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);beginText := 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
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年高考语文文言文总复习:文言句式(复习讲义)教师版
- 2025年公安辅警面考试模拟题库目(答案+解析)
- 2025年海南省东方市辅警招聘考试题库及答案
- 国家公务员考试时事政治题库及答案2025年
- 2025年全民国家安全教育日应知应会知识竞赛题及答案解析
- 2025年云南省丽江市事业单位工勤技能考试题库(含答案)
- 2025年贵州省福泉市继续教育公需课考试题(含答案)
- 晋城市2025年公需课考试题库及答案
- 2025年团员基本知识入团考试试题及答案
- 知道网课《西方文明史概论(湖南师范大学)》课后章节测试答案
- 2025年政工师考试试题及答案
- 孕优培训课件
- 2025广东高考物理第一轮基础练习:机械能守恒定律(有答案)
- 马工程西方经济学(精要本第三版)教案
- 《集成电路制造工艺项目化实践》 课件 项目5 晶圆测试工艺
- 新课标下的小学语文跨学科教学模式探讨
- 2025年物联网安装调试员(高级)技能鉴定考试题库
- 高一上册第三单元《永遇乐 京口北固亭怀古》
- 2025-2030年中国山葵制品行业运行现状及发展前景分析报告
- 银行支行行长2025年度工作计划
- 二零二五年度污水运输与污水处理厂合作运营合同
评论
0/150
提交评论