解決delphi TAdoQuery組件的close方法導(dǎo)致”列名無效“錯(cuò)誤的問題
1,故障現(xiàn)象
一次程序運(yùn)行,出現(xiàn)如下錯(cuò)誤:
對(duì)應(yīng)代碼如下:
2,故障分析
Query_alert_2的語句在查詢分析器中單獨(dú)執(zhí)行是正常的。排除語句出錯(cuò)。
如果注解掉Query_alert_1,則錯(cuò)誤變?yōu)镼uery_alert_3執(zhí)行出錯(cuò):
2019-07-11 09:32:26 Query_alert_1執(zhí)行完畢
2019-07-11 09:32:27 Query_alert_2執(zhí)行完畢
2019-07-11 09:32:42 Do_Update_Statis出錯(cuò):列名 'bat_pos1' 無效。
如果注解掉Query_alert_1、Query_alert_2,則Query_alert_3執(zhí)行正常。
可見,出現(xiàn)錯(cuò)誤是delphi內(nèi)數(shù)據(jù)庫(kù)組件產(chǎn)生的,與數(shù)據(jù)庫(kù)執(zhí)行無關(guān)。
3,故障原因及解決
數(shù)據(jù)庫(kù)版本的SQLServer2005,執(zhí)行的這些SQL語句含有臨時(shí)表,如:
if OBJECT_ID('tempdb..#t1')>0 drop table #t1
執(zhí)行正式的SQL之前,會(huì)運(yùn)行以上語句,以刪除當(dāng)前同名的臨時(shí)表。
但實(shí)際運(yùn)行發(fā)現(xiàn),這些臨時(shí)表不一定會(huì)被刪除,而當(dāng)引用時(shí),可能會(huì)引用到以前的臨時(shí)表,導(dǎo)致欄位不存在錯(cuò)誤。
因此,在Query_alert_1、Query_alert_2,Query_alert_3語句的最后,都加上drop 臨時(shí)表的語句,以確保臨時(shí)表在下次使用前一定不存在。如:
--檢查臨時(shí)表是否在用,有則刪除,以防錯(cuò)誤 if OBJECT_ID('tempdb..#t1')>0 drop table #t1 if OBJECT_ID('tempdb..#t2')>0 drop table #t2 /* 執(zhí)行相關(guān)業(yè)務(wù)邏輯SQL select * into #t1 from table1 。。。 。。。 */ --執(zhí)行完畢,清除臨時(shí)表,以便下次再使用 if OBJECT_ID('tempdb..#t1')>0 drop table #t1 if OBJECT_ID('tempdb..#t2')>0 drop table #t2
修改后,結(jié)果多條SQL語句順序執(zhí)行正常。
4,總結(jié)
關(guān)于數(shù)據(jù)庫(kù)臨時(shí)表,一定要注意在查詢器中執(zhí)行和在程序代碼中執(zhí)行是有區(qū)別的。
區(qū)別在于查詢器會(huì)自動(dòng)提交交易,并清除臨時(shí)表,而程序則不一定。
以上這篇解決delphi TAdoQuery組件的close方法導(dǎo)致”列名無效“錯(cuò)誤的問題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Delphi實(shí)現(xiàn)獲取磁盤空間大小的方法
這篇文章主要介紹了Delphi實(shí)現(xiàn)獲取磁盤空間大小的方法,是一個(gè)很實(shí)用的功能,需要的朋友可以參考下2014-07-07為什么繼續(xù)選擇DELPHI(即將逝去的Delphi前景在何方)
已經(jīng)鉆DELPHI很深了,當(dāng)然現(xiàn)在DELPHI是過了最輝煌的時(shí)代。但為什么要繼續(xù)下去,而不轉(zhuǎn)向其它的?這是不是死腦筋2018-02-02Delphi 實(shí)現(xiàn)軟件自動(dòng)升級(jí)的功能
這篇文章主要介紹了Delphi 實(shí)現(xiàn)軟件自動(dòng)升級(jí)的功能的相關(guān)資料,希望通過本文能幫助到大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-09-09Delphi 常見文件處理及注冊(cè)表文件的使用實(shí)例
這篇文章主要介紹了Delphi 常見文件處理及注冊(cè)表文件的使用實(shí)例的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-09-09Delphi實(shí)現(xiàn)窗體感知鼠標(biāo)滑過并自動(dòng)隱藏與顯示窗口的方法
這篇文章主要介紹了Delphi實(shí)現(xiàn)窗體感知鼠標(biāo)滑過并自動(dòng)隱藏與顯示窗口的方法,涉及Delphi操作窗口及鼠標(biāo)事件的技巧,需要的朋友可以參考下2015-05-05