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属性    转http://develop.csai.cn/delphi/200609131611001875.htm