一 发现原软件的问题:

1 不能对光盘名进行模糊查找;
2 结算栏目中一次只能查看一个用户;
3 报表功能太弱;
4 不太明白[用户还碟]-[结帐]到底有什么用;(已解决)
   将费用写入“收入信息表”内; 
  
5 [管理员信息维护]总是没有反应;(已解决)
    不是没反应,是软件的设置问题,只有第一号的管理员才能对管理员进行“添加”、“修改”和“删除”,其他管理员都无权对这个页面进行操作。

二 已解决问题:

1 光碟类型号只能显示字母代号而不能显示文字:
Delphi 的DBGrid 中的下拉列表和查找字段编程方法
  数据网格是非常流行的数据输入和显示形式,像大家熟悉的Excel、VFP 中的功能强大的BROWS 等,为广大程序员乐于采用。在用 Delphi 开发数据库应用系统时,利用数据网格DBGrid 输入数据时,有些字段只允许某几个固定的字符串,像档案案卷的保管期限,只有“永久”、“长期”和“短期”三种,可否从一个下拉列表中进行选择,从而方便输入和避免输入错误呢?还有一些字段,例如职工信息库中的单位编号(在另外的单位库中保存着单位的详细信息),在输入和显示职工数据时,能否不对单位编号进行操作,而代之于更加直观的单位库中的单位名称呢?答案是肯定的,Delphi 的数据网格控件 DBGrid,支持下拉列表和查找字段的编程,而且,编程的过程都是可视化的,不需要写一行语句。

DBGrid 中的下拉列表
    在 DBGrid 网格中实现下拉列表,设置好 DBGrid 中该字段的 PickList 字符串列表、初始的序号值 DropDownRows 即可。以职工信息库中的籍贯字段(字符串类型)为例,具体设计步骤如下:
  1、在窗体上放置Table1、DataSource1、DBGrid1、DBNavigator1 等控件对象,按下表设置各个对象的属性:

---------------------------------------
对象       属性         设定值
---------------------------------------
Table1       DataBase     sy1
             Table        zgk.dbf   file://职工信息库
DataSource1  DataSet      Table1
DbGrid1      DataSource   DataSource1
DBNavigator1 DataSource   Datasource1
-------------------------------------------
  2、双击Table1, 在弹出的Form1.Table1 窗口中,用右键弹出快捷菜单,单击Add Fields 菜单项;选择所有的字段后,按OK 按钮。

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

4、双击 DBGrid1, 在弹出的 Editing DBGrid1.Columns 窗口中,单击 Add all Fields 按钮,增加Table1 的所有字段。

5、在 Editing DBGrid1.Columns 窗口,选择 jg 这一行,切换到 Object Inspector 窗口,修改它的 PickList.Strings 为“湖北枝江市(换行)北京市(换行)河南平顶山市(换行)浙江德清市”

6、在 Form1.Oncreate 事件中写入语句:

Table1.Open;

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

DBGrid 中的查找字段
    所谓查找字段 (LookUp Field),即 DBGrid 中的某个关键字段的数值来源于另外一个数据库的相应字段。运用查找字段技术,不仅可以有效的避免输入错误,而且 DBGrid 的显示方式更为灵活,可以不显示关键字段,而显示源数据库中相对应的另外一个字段的数据。
---- 例如,我们在 DBGrid 中显示和编辑职工信息,包括职工编号、职工姓名、籍贯、所在单位编号,而单位编号来源于另一个数据库表格——单位库,称“单位编号”为关键字段。如果我们直接显示和编辑单位编号的话,将会面对1、2、3 等非常不直观的数字,编辑时极易出错。但是如果显示和编辑的是单位库中对应的单位名称话,将非常直观。这就是DBGrid 的所支持的查找字段带来的好处。

实现DBGrid 的查找字段同样不需要任何语句,具体设计步骤如下:
  1、在窗体上放置 Table1、Table2、DataSource1、DBGrid1、DBNavigator1 等控件对象,按下表设置各个对象的属性:

---------------------------------------
对象       属性         设定值
---------------------------------------
Table1       DataBase     sy1
             Table        zgk.dbf   file://职工信息库
Table2       DataBase     sy1
             Table        dwk.dbf   file://单位信息库
DataSource1  DataSet      Table1
DbGrid1      DataSource   DataSource1
DBNavigator1 DataSource   Datasource1
------------------------------------------
  2、双击 Table1, 在弹出的 Form1.Table1 窗口中,用右键弹出快捷菜单,单击 Add Fields 菜单项;选择所有的字段后,按OK 按钮。

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

4、设置 Table1DWBH.Visible=False。

5、在 Form1.Table1 窗口,用右键弹出快捷菜单,单击 New Field 菜单项,新增一个查找字段DWMC,在弹出的窗口设置相应的属性, 按 OK 按钮确认;在 Object Inspector 窗口,设置 Table1DWMC.DisplayLabel= 单位名称。

6、在 Form1.Oncreate 事件中写入语句:

Table1.Open;

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

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

2005年2月11日相关推荐

  1. 【历史上的今天】8 月 11 日:苹果电脑之父诞生;阿里巴巴收购雅虎中国;OpenAI 击败电竞世界冠军

    整理 | 王启隆 透过「历史上的今天」,从过去看未来,从现在亦可以改变未来. 今天是 2022 年 8 月 11 日,在 1999 年的今天,欧亚一些地区观赏到了一次壮丽的日全食景象.这次日全食是本世 ...

  2. 【历史上的今天】1 月 11 日:Mac Mini 问世;ALGOL 60 诞生;人类首次关闭 FM 广播

    整理 | 王启隆 透过「历史上的今天」,从过去看未来,从现在亦可以改变未来. 今天是 2022 年 1 月 11 日,在 222 年前的今天(1800 年),直流发电机之父耶德利克·阿纽什(Jedli ...

  3. 阿里巴巴并购雅虎中国[北京时间8月11日14时]

    北京时间 8 月 11 日 14 时 ,阿里巴巴(中国)网络技术有限公司在北京宣布,全面收购雅虎中国全部资产 ,其中包括雅虎中国门户网站( www.yahoo.com.cn ).搜索门户 " ...

  4. C++/CLI标准化工作告一段落![原文发表时间:2005年9月22日]

    原文出处:http://pluralsight.com/blogs/hsutter/archive/2005/09/22/14970.aspx 2003年11月,Ecma(译者注:欧洲计算机厂商协会) ...

  5. 2005年06月30日 启功先生逝世 [前段时间上网不方便,今天才知道]

    我国著名国学大师.书画大师启功先生逝世   2005年06月30日11:49 [字号 大 中 小][留言][论坛][打印][关闭] 我国著名国学大师.书画大师,北京师范大学教授启功先生因病于30日凌晨 ...

  6. 服务器维护10月11魔兽,魔兽世界10月11日更新内容是什么_10.11PVP改动预览_3DM网游...

    魔兽世界10月11日将会对游戏进行修正,改动内容主要是PVP方面,很多小伙伴对此并不清楚,因此小编下面就为大家带来魔兽世界10月11日更新预览,一起来看看吧. <魔兽世界>10月11日更新 ...

  7. D2 日报 2019年6月11日

    ? 开源项目 ➡️ sfyc23/EverydayWechat watch 34 star 1690 fork 317 每日自动给女朋友发微信暖心话. github.com ➡️ YMFE/yapi ...

  8. 第二期安全狗讲坛3月11日开始

    2019独角兽企业重金招聘Python工程师标准>>> 3月4日下午3点,第一期"安全狗讲坛"在安全狗论坛开展,在广大枸杞的热心参与下,整个讲坛火热且有序,并在一 ...

  9. 用C#制作新闻阅读器(电脑报2005年3月14日 第10期)

    一.弄清结构再动手    要想轻松的抽取RSS信息,自然先要了解它的结构,所谓"知己知彼,百战不殆"嘛. 1.RSS的结构    我们先打开百度新闻一个RSS链接,如果你再多打开几 ...

最新文章

  1. 方差分析(Analysis of Variance,ANOVA)是什么?方差分析的形式有哪些?
  2. 算法竞赛入门与进阶 (一)枚举
  3. python多线程操作字典_在Python中使用带有线程的全局字典
  4. 流行前沿的暗黑APP主题UI设计素材模板
  5. 翁恺老师C语言学习笔记(十)指针_指针运算
  6. 你都有哪些丢人的经历?
  7. linux修改端口监听地址,修改nginx/Tomcat等Web服务的端口监听地址
  8. P. Laguna/Evaluation of an Automatic Threshold Based Detector of Waveform Limits in Holter ECG
  9. Xcode工程添加第三方文件的详细分析 Create folder references for any added folders
  10. ArcGISEngine二次开发(1):系统基本功能
  11. linear-gradient常用实现效果
  12. HBase二级索引实现方案
  13. java与seo_seo和java哪个更好!
  14. Cannot forward after response has been committe
  15. 训练GAN,你应该知道的二三事
  16. Java实现房屋租赁网站
  17. pacemaker+corosync+pcs
  18. PLSQL创建Oracle定时任务,定时执行存储过程
  19. js中settimeout的终止
  20. 定向光和天空盒(个人笔记)

热门文章

  1. 爬取淘宝python书籍销售情况动态网页
  2. 你知道吗?没有硅胶消泡剂,避孕套可能都不安全了
  3. 2020 中国软件企业 100 强,腾讯第二、阿里第三,第一竟然是他!
  4. 国产高速光耦OR-2630、OR-2631,对标ICPL2630,质优价廉
  5. python能做什么兼职-学会python可以做哪些兼职?
  6. 【五】Socket函数详解
  7. html 微信无法获取图片,微信浏览器input file 图片选择问题,获取不到图片的type等信息...
  8. 一文读懂机器阅读理解
  9. 测试自己是音痴的软件,你有多聪明?(测试)
  10. 《高效的秘密》第一章,第二章读后感