在Delphi数据库应用程序中常见错误
下是Delphi数据库应用程序中常见错误、原因/解决方法:
数据感知控件DataSource属性未设置或者设置错误(链接为其他的DataSource)
原因:在设计时不小心改动,拷贝粘贴过程中未全部更改
测试时标准代码中没有数据,无法进行测试
解决:确定需要输入数据的表格的先后顺序,在依次输入测试数据,再进行测试
wwFilterDialog中进行数据过滤时,应该显示字段列表的字段没有显示,不方便输入
解决:判断字段,查找标码填充字段列表
运行程序时出现字段未找到的错误
原因:数据库进行了更改,而DataSet的字段列表没有更新
用DBGrid显示数据时,为方便阅读,单数行与奇数行用不同颜色显示,在数据量时,浏览数据时明显感觉到DBGrid数据刷新不够,单数行与奇数行的颜色不能正确显示
原因:DBGrid的 DataSource的DataSet中有较多的查找字段
解决:将部分查找字段去除
窗体标题为英文
原因:设计后未仔细检查
解决:更改为中文
DBNavigator中“刷新”按钮点击后出错
原因未知
解决:去除该按钮
与dxDBGrid配套使用的DBNavigator,在dxDBGrid的模式为LoadAll时,导航按钮与期望的方式不同
原因:dxDBGrid在LoadAll模式时,与DataSet中的数据不一致
解决:去除导航中的部分按钮
由存储过程得到的数据集对应的DBNavigator的“刷新”出错
原因:不清
解决:去除该按钮
窗体Show后,进入数据编辑后,部分查找字段编辑时出现数据集未打开
原因:数据集打开顺序有问题
解决:调整数据集的打开顺序,让标码数据集先打开
出现未找到存储过程的错误
原因:数据库的存储过程进行的重命名
解决:更改DataSource中的存储程序名称
wwFilterDialog的标题空白
解决:改为与数据集相关的标题,如“筛选计划”
窗体在1024*768下设计时,即使窗体为800*600,在屏幕分辨率为800*600的时候出现窗体中的内容不能全部显示的现象
解决:1024*768下设计800*600时预留一定的空间
出现“Couldno’t perform the edit because another user changed the record”错误
原因:未知
dxDBGrid在将字段拖曳到分组栏时,不能进行编辑:dxDBGrid中的当前记录与数据感知控件的当前记录不一致
解决:将二者在不同部分实现,不在同一窗体实现
出现“General SQL Error”错误
原因:未知。但发现在FormShow中打开表很多,尝试将其中部分表不打开时,错误消失,且不打开的表不同时,错误都消失
(系统休眠后)第一次连接数据库时(用户、口令均正确),出现错误,但第二次则正常
原因:未知
打开/保存对话框未设置过滤条件
解决:设置合理的Filter、DefaultExt
防差错措施不完善。(如输入数据(数字)出错时不报警)
解决:保存前验证正确性判断,设置Mask
数据感知控件DBComboBox应可进行选择和输入的输入框,不能进行输入
解决:更改Style属性为csDropDown
其他更一般的问题:
模态对话框,Escape键不起作用
解决:合理设置Button的Canceled属性
模态对话框,回车键不起默认作用
解决:合理设置Button的Defaulted属性
使用Tab键后焦点跳转顺序无规律
解决:设置控件的TabOrder属性