Delphi TAdoQuery组件的close方法为何会导致列名无效错误,能否详细解释一下原因?

2026-04-10 17:422阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计342个文字,预计阅读时间需要2分钟。

Delphi TAdoQuery组件的close方法为何会导致列名无效错误,能否详细解释一下原因?

1. 故障现象:一次程序运行,出现如下错误: 1. 对应代码如下:

2. 故障分析:Query_alert_2的语句在查询分析器中单独执行是正常的。排除语句错误。 1. 如果注释掉Query_alert_1,错误变为Que。

1,故障现象

一次程序运行,出现如下错误:

对应代码如下:

2,故障分析

Query_alert_2的语句在查询分析器中单独执行是正常的。排除语句出错。

Delphi TAdoQuery组件的close方法为何会导致列名无效错误,能否详细解释一下原因?

如果注解掉Query_alert_1,则错误变为Query_alert_3执行出错:

2019-07-11 09:32:26 Query_alert_1执行完毕

2019-07-11 09:32:27 Query_alert_2执行完毕

2019-07-11 09:32:42 Do_Update_Statis出错:列名 ‘bat_pos1‘ 无效。

如果注解掉Query_alert_1、Query_alert_2,则Query_alert_3执行正常。

可见,出现错误是delphi内数据库组件产生的,与数据库执行无关。

3,故障原因及解决

将执行过程中TADOQuery的close方法改为 “active := False”,如下:

结果多条SQL语句顺序执行正常。

4,总结

网上查询TADOQuery的close方法和设置属性“active := False”有何区别,发现大部分是说,query.close和query.active:=false 意义一样
按ctrl 点击close 会发现 close 就是设置active为false

那为何实际代码执行效果却不一样呢?令人费解。看来坑还是不少的。

标签:close方法

本文共计342个文字,预计阅读时间需要2分钟。

Delphi TAdoQuery组件的close方法为何会导致列名无效错误,能否详细解释一下原因?

1. 故障现象:一次程序运行,出现如下错误: 1. 对应代码如下:

2. 故障分析:Query_alert_2的语句在查询分析器中单独执行是正常的。排除语句错误。 1. 如果注释掉Query_alert_1,错误变为Que。

1,故障现象

一次程序运行,出现如下错误:

对应代码如下:

2,故障分析

Query_alert_2的语句在查询分析器中单独执行是正常的。排除语句出错。

Delphi TAdoQuery组件的close方法为何会导致列名无效错误,能否详细解释一下原因?

如果注解掉Query_alert_1,则错误变为Query_alert_3执行出错:

2019-07-11 09:32:26 Query_alert_1执行完毕

2019-07-11 09:32:27 Query_alert_2执行完毕

2019-07-11 09:32:42 Do_Update_Statis出错:列名 ‘bat_pos1‘ 无效。

如果注解掉Query_alert_1、Query_alert_2,则Query_alert_3执行正常。

可见,出现错误是delphi内数据库组件产生的,与数据库执行无关。

3,故障原因及解决

将执行过程中TADOQuery的close方法改为 “active := False”,如下:

结果多条SQL语句顺序执行正常。

4,总结

网上查询TADOQuery的close方法和设置属性“active := False”有何区别,发现大部分是说,query.close和query.active:=false 意义一样
按ctrl 点击close 会发现 close 就是设置active为false

那为何实际代码执行效果却不一样呢?令人费解。看来坑还是不少的。

标签:close方法