没有翅膀得鸟 發表於 2020-2-15 14:33:00

解决delphi TAdoQuery组件的close方法导致”列名无效“错误的问题

<p><strong>1,故障现象</strong></p>
<p>一次程序运行,出现如下错误:</p>
<p><img alt="" src="https://img.jbzj.com/file_images/article/202002/20200215143129.jpg" /></p>
<p>对应代码如下:</p>
<p><img alt="" src="https://img.jbzj.com/file_images/article/202002/20200215143137.jpg" /></p>
<p><strong>2,故障分析</strong></p>
<p>Query_alert_2的语句在查询分析器中单独执行是正常的。排除语句出错。</p>
<p>如果注解掉Query_alert_1,则错误变为Query_alert_3执行出错:</p>
<p>2019-07-11 09:32:26 Query_alert_1执行完毕</p>
<p>2019-07-11 09:32:27 Query_alert_2执行完毕</p>
<p>2019-07-11 09:32:42 Do_Update_Statis出错:列名 'bat_pos1' 无效。</p>
<p>如果注解掉Query_alert_1、Query_alert_2,则Query_alert_3执行正常。</p>
<p>可见,出现错误是delphi内数据库组件产生的,与数据库执行无关。</p>
<p><strong>3,故障原因及解决</strong></p>
<p>数据库版本的SQLServer2005,执行的这些SQL语句含有临时表,如:</p>
<div class="jb51code">
<pre class="brush:plain;">
if OBJECT_ID('tempdb..#t1')&gt;0
drop table #t1</pre>
</div>
<p>执行正式的SQL之前,会运行以上语句,以删除当前同名的临时表。</p>
<p>但实际运行发现,这些临时表不一定会被删除,而当引用时,可能会引用到以前的临时表,导致栏位不存在错误。</p>
<p>因此,在Query_alert_1、Query_alert_2,Query_alert_3语句的最后,都加上drop 临时表的语句,以确保临时表在下次使用前一定不存在。如:</p>
<div class="jb51code">
<pre class="brush:plain;">
--检查临时表是否在用,有则删除,以防错误
if OBJECT_ID('tempdb..#t1')&gt;0
drop table #t1

if OBJECT_ID('tempdb..#t2')&gt;0
drop table #t2

/*
执行相关业务逻辑SQL

select *
into #t1
from table1

。。。
。。。
*/

--执行完毕,清除临时表,以便下次再使用
if OBJECT_ID('tempdb..#t1')&gt;0
drop table #t1

if OBJECT_ID('tempdb..#t2')&gt;0
drop table #t2</pre>
</div>
<p>修改后,结果多条SQL语句顺序执行正常。</p>
<p><img alt="" src="https://img.jbzj.com/file_images/article/202002/20200215143147.jpg" /></p>
<p><strong>4,总结</strong></p>
<p>关于数据库临时表,一定要注意在查询器中执行和在程序代码中执行是有区别的。</p>
<p>区别在于查询器会自动提交交易,并清除临时表,而程序则不一定。</p>
<p>以上这篇解决delphi TAdoQuery组件的close方法导致”列名无效“错误的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持琼殿技术社区。</p>
                           
                            <div class="art_xg">
                              <b>您可能感兴趣的文章:</b><ul><li>selenium框架中driver.close()和driver.quit()关闭浏览器</li><li>详解Java 中的 AutoCloseable 接口</li><li>探索浏览器页面关闭window.close()的使用详解</li><li>PyQt5 closeEvent关闭事件退出提示框原理解析</li><li>Python Selenium 之关闭窗口close与quit的方法</li><li>PHP PDOStatement::closeCursor讲解</li><li>CLOSE_WAIT状态解决方案</li></ul>
                            </div>

                        </div>
                        <!--endmain-->
頁: [1]
查看完整版本: 解决delphi TAdoQuery组件的close方法导致”列名无效“错误的问题