论坛登陆 用户: 密码:
联系我们
设为首页
加入收藏
业界新闻 网络编程 程序开发 网页图象 聊天通讯 软件应用 网络安全 硬件学堂 教育频道 站长club
  ·推荐新闻
 
·美前任官员认为amd告倒英特
·搜索引擎关键字排行简介
·网站优化教程(一)
·msn近期遭受木马病毒骚扰 用
·用qq管理你的系统^_^ 
·测评中心金山毒霸联合发布7
·qq群聊实名 普通用户不受影
·雅虎思科联手推数字邮件签名
·这18条背下来没人敢和你忽悠
·自己动手,拯救丢失的硬盘数
  ·资料搜索
 
  ·相关文章
·制作用于日期时间型字段的delp
·数据库应用程序开发中图像数据
·delphi 中使用计算出的字段
·在delphi中建立和使用别名
·用delphi实现将纯文本资料转入
·tdbgrid控件中对多个记录的处理
·在delphi动态生成定义数据库
·用delphi编程访问sqlserver数据
·在dbgrid中实现copy、paste功能
  ·热门新闻
首页>>程序开发>>delphi >>文章正文

dbgrid中的下拉列表和查找字段编程方法


 日期:2005-7-18 9:00:37     来源:易特网络技术   编辑:黑鹰  点击:
p align="left">
  数据网格是非常流行的数据输入和显示形式,像大家熟悉的excel97、vfp中的功能强大的brows等,为广大程序员乐于采用。在用delphi3开发数据库应用系统时,利用数据网格dbgrid输入数据时,有些字段只允许某几个固定的字符串,像档案案卷的保管期限,只有“永久”、“长期”和“短期”三种,可否从一个下拉列表中进行选择,从而方便输入和避免输入错误呢?还有一些字段,例如职工信息库中的单位编号(在另外的单位库中保存着单位的详细信息),在输入和显示职工数据时,能否不对单位编号进行操作,而代之于更加直观的单位库中的单位名称呢?答案是肯定的,delphi3的数据网 格控件dbgrid,支持下拉列表和查找字段的编程,而且,编程的过程都是可视化的,不需要写一行语句。

一、dbgrid中的下拉列表
  在dbgrid网格中实现下拉列表,设置好dbgrid中该字段的picklist字符串列表、初始的序号值dropdownrows即可。以职工信息库中的籍贯字段(字符串类型)为例,具体设计步骤如下:

  1、在窗体上放置table1、datasource1、dbgrid1、dbnavigator1等控件对象,按下表设置各个对象的属性:

对象 属性 设定值
table1 database sy1
tablename zgk.dbf //职工信息库
datasource1 dataset table1
dbgrid1 datasource datasource1
dbnavigator1 datasource datasource1


  2、双击table1,在弹出的form1.table1窗口中,用右键弹出快捷菜单,单击addfields菜单项;选择所有的字段后,按ok按钮。

  3、修改第2步新增字段的displaylabel属性。以table1zgbh字段为例,在objectinspector窗口中选择table1zgbh,修改属性displaylabel=职工编号,其余字段类似。

  4、双击dbgrid1,在弹出的editing dbgrid1.columns窗口中,单击addallf ds按钮,增加table1的所有字段。

  5、在editingdbgrid1.columns窗口,选择jg这一行,切换到objectinspector窗口,修改它的picklist.strings为“湖北枝江市、北京市、河南平顶山市、浙江德清市”

  6、在form1.oncreate事件中写 入语句:
table1.open;

  7、f9运行,用鼠标点击某个记录的籍贯字段,右边即出现一个按钮,点击这个按钮,可出现一个下拉列表,包含第5步中输入的四行字符串,可用鼠标进行选择。当然也可以自行输入一个并不属下拉列表中的字符串。

二、dbgrid中的查找字段
  所谓查找字段(lookupfield),即dbgrid 中的某个关键字段的数值来源于另外一个数据库的相应字段。运用查找字段技术,不仅可以有效的避免输入错误,而且dbgrid的显示方式更为灵活,可以不显示关键字段,而显示源数据库中相对应的另外一个字段的数据。

  例如,我们在dbgrid中显示和编辑职工信息,包括职工编号、职工姓名、籍贯、所在单位编号,而单位编号来源于另一个数据库表格——单位库,称“单位编号”为关键字段。如果我们直接显示和编辑单位编号的话,将会面对1、2、3等非常不直观的数字,编辑时极易出错。但是如果显示和编辑的是单位库中对应的单位名称话,将非常直观。这就是dbgrid的所支持的查找字段带来的好处。

  实现dbgrid的查找字段同样不需要任何语句,具体设计步骤如下:
  1、在窗体上放置table1、table2、datasource1、dbgrid1、dbnavigator1等控件对象,按下表设置各个对象的属性:

对象 属性 设定值
table1 database sy1
tablename zgk.dbf //职工信息库
table2 database sy1
tablename dwk.dbf //单位信息库
datasource1 dataset table1
dbgrid1 datasource datasource1
dbnavigator1 datasource datasource1

  2、双击table1,在弹出的form1.table1窗口中,用右键弹出快捷菜单,单击addfields菜单项;选择所有的字段后,按ok按钮。

  3、修改第2步新增字段的displaylabel属性。以table1zgbh字段为例,在objectinspector窗口中选择table1zgbh,修改属性displaylabel=职工编号,其余字段类似。

  4、设置table1dwbh.visible=false。

  5、在form1.table1窗口,用右键弹出快捷菜单,单击newfield菜单项,新增一个查找字段dwmc,在弹出的窗口设置相应的属性,按ok按钮确认;在objectinspector窗口,设置table1dwmc.displaylabel= 单位名称。

  6、在form1.oncreate事件中写 入语句:
  table1.open;

  7、按f9运行,当光标移至某个记录的单位名称字段时,用鼠标点击该字段,即出现一个下拉列表,点击右边的下箭头,可在下拉列表中进行选择。在这里可以看出,下拉列表的内容来自于单位信息库,并且不能输入其他内容。

三、dbgrid中的下拉列表和查找字段的区别
  虽然dbgrid中的下拉列表和查找字段,都是以下拉列表的形式出现的,但两者有很大的差别。
  1、用picklist属性设置的下拉列表,它的数据是手工输入的,虽然也可以在程序中修改,但动态特性显然不如直接由另外数据库表格提取数据的查找字段。

  2、用picklist属性设置的下拉列表,允许输入不属于下拉列表中的数据,但查找字段中只能输入源数据库中关键字段中的数据,这样更能保证数据的完整性。

  3、用picklist属性设置的下拉列表设计较为简单。

上一篇:在delphi中建立和使用别名
下一篇:delphi 中使用计算出的字段
[发送给好友] [打印本页] [关闭窗口] [返回顶部转载请注明来源:http://www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 黑鹰 投稿作者: 易特网络
信息来源: 易特网络技术 录入时间: 2005-7-18 9:00:37
浏览次数: 投稿信箱: shtghy@163.com
设置首页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
copyrights ©2004-2005 iyit.net all rights reserved. 网站合作、广告联系qq:147007642、466949678
易特网络技术 点击这里给我发消息