博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
“在对应所需名称或序数的集合中,未找到项目”问题的解决方法
阅读量:6203 次
发布时间:2019-06-21

本文共 741 字,大约阅读时间需要 2 分钟。

在BCB或Delphi中,使用ADOQuery进行数据库的操作,经常会遇到“在对应所需名称或序数的集合中,未找到项目”的问题。这个问题是由于ADOQuery中使用了当前表中没有的字段造成的。

出错原因:

1.在ADOQuery中使用了Filter属性,并且设置Filter的值。在使用同一个ADOQuery进行另一个表的操作时,此Filter的值还是存在的,系统不会自动清除,于是出现了上面的问题。

解决方法:

1.对于需要用同一个ADOQuery解决不同的数据库表操作的时候,在对第二张表进行操作,执行ADOQuery->Open之前,执行ADOQuery->Filtered = false,这样上面的问题就可以解决了。

   在Delphi中,如果使用ADOQuery对数据进行修改保存,在修改保存了第一次以后,如果再次进行修改保存,就会遇到“无法为更新定位行,一些值可能已在最后一次读取后已更改”的问题。 

原因有这样几种:

1.在数据库设计时,为某些字段设置了默认值,在修改进行提交以后,数据库会自动修改对应字段的所有行的默认值,从而导致了数据库与数据集中数据的不一致,使ADOQuery无法对数据集进行定位。

2.数据库对应的表没有主键,输入了重复的数据以后,数据库里有两条一样的数据,从而使ADOQuery无法对数据进行定位。

解决方法:

1.修改数据库设计,不再设置默认值,为数据库表定义主键,保证其唯一性。

2.在执行完ADOQuery.Post之后,执行ADOQuery.Refresh,对于设置默认值的情况可以解决。

本文转自鹅倌51CTO博客,原文链接:http://blog.51cto.com/kaixinbuliao/1536283 ,如需转载请自行联系原作者
你可能感兴趣的文章
数据结构探险系列—栈篇-学习笔记
查看>>
区块链开发公司谈区块链在商业上的应用
查看>>
开发工具总结(2)之全面总结Android Studio2.X的填坑指南
查看>>
Unity3D手机斗地主游戏开发实战(02)_叫地主功能实现
查看>>
qt日志实现
查看>>
Lottie 站在巨人的肩膀上实现 Android 酷炫动画效果
查看>>
研究笔记:iOS中使用WebViewProxy拦截URL请求
查看>>
用尽洪荒之力整理的Mysql数据库32条军规
查看>>
Linux_异常_08_本机无法访问虚拟机web等工程
查看>>
Spring For All 顶级Spring综合社区服务平台
查看>>
linux系统编程
查看>>
VS Code 的常用快捷键和插件
查看>>
JS入门熟知
查看>>
Java 打包 FatJar 方法小结
查看>>
使用 Pandas 分析 Apache 日志
查看>>
新建VUX项目
查看>>
Spring MVC & Boot & Cloud 技术教程汇总(长期更新)
查看>>
这份NLP研究进展汇总请收好,GitHub连续3天最火的都是它
查看>>
博客园代码黑色主题高亮设置
查看>>
Linux常用快捷键
查看>>