有沒有人遇過降子的情況? |
尚未結案
|
Mecer
初階會員 發表:15 回覆:30 積分:29 註冊:2002-10-25 發送簡訊給我 |
大家好~~ 目前資料庫用的是Oracle 8.1.7,開發了一個專案,結果我寫了一小段SQL Script居然查不到資料?
我用了一個TDataBase, 一個TQuery,Query內的Script如下: Select *
From cust
Where custno = :custno 程式如下: with Query1 do
begin
Close;
ParamByName('custno').asString := 'A0001';
Open;
if NOT Eof then
...
else
...
Close;
end; 當我無論傳什麼資料給:custno這個變數,得到的結果都是Eof,大小寫的資料都試過了,怎麼傳都沒用,可是如果我在程式裡動態的把SQL Script組起來,再丟給Query去執行,就沒問題?!怎麼會降子?我確定給的資料沒問題...
|
Fishman
尊榮會員 發表:120 回覆:1949 積分:2163 註冊:2006-10-28 發送簡訊給我 |
Hi Mecer, 1.建議你改用 IsEmpty 屬性來判定 TQuery 是否有值回傳
with Query1 do begin Close; ParamByName('custno').asString := 'A0001'; Open; if NOT IsEmpty then ... else ... Close; end;2.開啟 SQL Monitor 確認該 Query 確實有值回傳 ---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ----------------------------------
------
Fishman |
kevin622
一般會員 發表:0 回覆:22 積分:9 註冊:2003-10-16 發送簡訊給我 |
|
Chance36
版主 發表:31 回覆:1033 積分:792 註冊:2002-12-31 發送簡訊給我 |
引言: with Query1 do begin Close; ParamByName('custno').asString := 'A0001'; Open; if NOT Eof then ... else ... Close; end;Mecer 你好 好像看過Oracle的Char型態會將內容填滿空白到所設定的欄位寬度,你可以試試如下程式: with Query1 do begin Close; ParamByName('custno').asString := 'A0001 '; // 假設欄位寬度為8個字元寬 Open; if NOT Eof then ... else ...我用Paradox及MSSQL及MySQL從沒發生過這種現象。 |
m510011
一般會員 發表:18 回覆:18 積分:7 註冊:2002-05-16 發送簡訊給我 |
|
m510011
一般會員 發表:18 回覆:18 積分:7 註冊:2002-05-16 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |