線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:2495
推到 Plurk!
推到 Facebook!

Delphi5程式升級到Delphi2010遇到SQL使用SUM、COUNT函數查詢出現Operation not applicable?

缺席
OwHong
一般會員


發表:2
回覆:1
積分:0
註冊:2003-06-17

發送簡訊給我
#1 引用回覆 回覆 發表時間:2012-04-01 22:57:40 IP:124.11.xxx.xxx 訂閱
公司的系統是Delphi5開發的三層式架構,最近開始陸續升級成Delphi2010,
所以使用Delphi2010重新Compiler Delphi5的程式,

AP端程式很單純,只有連接Oracle DB的功能,並沒有特殊處理邏輯,使用RemoteDataModule元件,裡面放了幾個ADOQuery和DataSetProvider。

Client端程式:使用DataModule元件,裡面放1個DCOMConnection元件 -> 連接AP的電腦,並設定好ServerName和ServerGUID屬性;
放ClientDataSet -> 設定好RomoteServer和ProviderName
放DataSource -> 設定好DataSet

直接在ClientDataSet元件上的CommandText輸入SQL語法,可正常Active起AP程式,如下圖一。
程式Compiler後,在目前開發的電腦上執行相同的SQL語法,確實可正常執行,畫面的DBGrid有顯示出查詢結果。

但奇怪的事情發生了,我將執行檔放到User的電腦上執行時,相同的語法卻會出現Operation not applicable.錯誤訊息
,如圖二

目前測試過只有Select的欄位有Sum、Count這種統計函數的就會出現此錯誤訊息,其他正常的欄位就可正常執行,
另外也測試過若Client直接使用ADOQuery的方式查詢(二層式架構),也可正常執行,
因為User電腦並不會直接連到DB,所以一定要使用三層式架構的方式,
請教是否有高手遇此狀況,三層式架構需要做什麼元件屬性設定可以解決這個怪問題??





jcjroc
高階會員


發表:21
回覆:276
積分:114
註冊:2002-09-18

發送簡訊給我
#2 引用回覆 回覆 發表時間:2012-07-19 12:26:29 IP:59.124.xxx.xxx 訂閱
給你個建議,不要在Application中下SQL Command,除了exec外
所有DB的Setect ,insert ,update交由預存程序去做,
系統時間:2017-10-19 22:32:59
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!