請問如下的程式碼錯在哪裡?如何才正確? |
答題得分者是:cashxin2002
|
BIG-ROM
初階會員 發表:94 回覆:91 積分:37 註冊:2005-04-16 發送簡訊給我 |
procedure TINVOICE.SpeedButton1Click(Sender: TObject);
var
INVO: string;
begin
IF ComboBox.Text='All_Invoice' Then
INVO:='SELECT * FROM [INVOICE] order by INID Desc'
ELSE IF ComboBox.Text='InvoiceNumber' Then
INVO:='SELECT * FROM [INVOICE] WHERE InvoiceNumber='+Edit1.Text+' order by INID Desc'
ELSE IF ComboBox.Text='Cntr_No' Then
INVO:='SELECT * FROM [INVOICE] WHERE CntrNo like '+Edit1.Text+' order by INID Desc'
ELSE
begin
with LJSJK.INVOICE do
begin
Close;
SQL.Clear;
SQL.Add(INVO);
TRY
Open;
except
ExecSQL;
FREE;
end;
end;
end;
end; 當選擇InvoiceNumber再輸入條件進行搜索時就出現上面圖的錯誤。 希望實現功能如下: 1. 選擇InvoiceNumber時無須輸入條件直接按搜索按鈕展示所有資料;
2. 當選擇其他選項時必須輸入相應的搜索內容進行相應的搜索。 請個位高高手幫忙,感謝!感謝!! 寫程序——新問題會接踵而來!
|
Chance36
版主 發表:31 回覆:1033 積分:792 註冊:2002-12-31 發送簡訊給我 |
procedure TINVOICE.SpeedButton1Click(Sender: TObject); var INVO: string; begin IF ComboBox.Text='All_Invoice' Then INVO:='SELECT * FROM [INVOICE] order by INID Desc' ELSE IF ComboBox.Text='InvoiceNumber' Then INVO:='SELECT * FROM [INVOICE] WHERE InvoiceNumber=' Edit1.Text ' order by INID Desc' //<== OK ELSE IF ComboBox.Text='Cntr_No' Then INVO:='SELECT * FROM [INVOICE] WHERE CntrNo like ''' Edit1.Text ''' order by INID Desc' //<== 注意紅色的單引號 ELSE begin with LJSJK.INVOICE do begin Close; SQL.Clear; //SQL.Add(INVO); <== INVO並沒有內容呀! SQL.Add('SELECT * FROM [INVOICE] order by INID Desc'); <== 改成這樣看看 TRY Open; except ExecSQL; FREE; end; end; end; end;_______________________________________ 深藍的魚,祝您好運..........連連 |
cashxin2002
版主 發表:231 回覆:2555 積分:1937 註冊:2003-03-28 發送簡訊給我 |
您好﹗
procedure TINVOICE.SpeedButton1Click(Sender: TObject); var INVO: string; begin IF ComboBox.Text='All_Invoice' Then INVO:='SELECT * FROM [INVOICE] order by INID Desc' ELSE IF ComboBox.Text='InvoiceNumber' Then INVO:='SELECT * FROM [INVOICE] WHERE InvoiceNumber='''+Edit1.Text+''' order by INID Desc' ELSE IF ComboBox.Text='Cntr_No' Then INVO:='SELECT * FROM [INVOICE] WHERE CntrNo like '''+Edit1.Text+''' order by INID Desc' ELSE//刪除這個ELSEbegin with LJSJK.INVOICE do begin Close; SQL.Clear; SQL.Add(INVO); TRY Open; except ExecSQL; FREE; end; end; end; end;================================= 有空來瞅瞅我﹗因為我是您的朋友﹐有您真好﹗ ================================
------
忻晟 |
BIG-ROM
初階會員 發表:94 回覆:91 積分:37 註冊:2005-04-16 發送簡訊給我 |
|
cashxin2002
版主 發表:231 回覆:2555 積分:1937 註冊:2003-03-28 發送簡訊給我 |
您好﹗ LJSJK.INVOICE是資料集元件的名稱嗎﹖發現是和Form的名稱相同﹐請問是使用何元件﹖如果不是資料集元件﹐以下紅色處就缺少了資料集元件的名稱﹐如果确定是資料集元件的話﹐改成如下試試﹕
procedure TINVOICE.SpeedButton1Click(Sender: TObject); var INVO: string; begin IF ComboBox.Text='All_Invoice' Then INVO:='SELECT * FROM [INVOICE] order by INID Desc' ELSE IF ComboBox.Text='InvoiceNumber' Then INVO:='SELECT * FROM [INVOICE] WHERE InvoiceNumber='''+Edit1.Text+''' order by INID Desc' ELSE IF ComboBox.Text='Cntr_No' Then INVO:='SELECT * FROM [INVOICE] WHERE CntrNo like '''+Edit1.Text+''' order by INID Desc' With LJSJK.INVOICE do begin Close; SQL.Clear; SQL.Add(INVO); Open; end; end;================================= 有空來瞅瞅我﹗因為我是您的朋友﹐有您真好﹗ ================================
------
忻晟 |
cxh17895
初階會員 發表:13 回覆:37 積分:25 註冊:2003-03-19 發送簡訊給我 |
|
Arlung Miao
初階會員 發表:9 回覆:44 積分:25 註冊:2004-08-25 發送簡訊給我 |
|
BIG-ROM
初階會員 發表:94 回覆:91 積分:37 註冊:2005-04-16 發送簡訊給我 |
|
BIG-ROM
初階會員 發表:94 回覆:91 積分:37 註冊:2005-04-16 發送簡訊給我 |
您好。
LJSJK.INVOICE LJSJK====是數據模塊
INVOICE===ADOWuery
引言: 您好﹗ LJSJK.INVOICE是資料集元件的名稱嗎﹖發現是和Form的名稱相同﹐請問是使用何元件﹖如果不是資料集元件﹐以下紅色處就缺少了資料集元件的名稱﹐如果确定是資料集元件的話﹐改成如下試試﹕寫程序——新問題會接踵而來!procedure TINVOICE.SpeedButton1Click(Sender: TObject); var INVO: string; begin IF ComboBox.Text='All_Invoice' Then INVO:='SELECT * FROM [INVOICE] order by INID Desc' ELSE IF ComboBox.Text='InvoiceNumber' Then INVO:='SELECT * FROM [INVOICE] WHERE InvoiceNumber='''+Edit1.Text+''' order by INID Desc' ELSE IF ComboBox.Text='Cntr_No' Then INVO:='SELECT * FROM [INVOICE] WHERE CntrNo like '''+Edit1.Text+''' order by INID Desc' With LJSJK.INVOICE do begin Close; SQL.Clear; SQL.Add(INVO); Open; end; end;================================= 有空來瞅瞅我﹗因為我是您的朋友﹐有您真好﹗ ================================ |
Arlung Miao
初階會員 發表:9 回覆:44 積分:25 註冊:2004-08-25 發送簡訊給我 |
|
BIG-ROM
初階會員 發表:94 回覆:91 積分:37 註冊:2005-04-16 發送簡訊給我 |
|
cashxin2002
版主 發表:231 回覆:2555 積分:1937 註冊:2003-03-28 發送簡訊給我 |
您好﹗ 用Try和Except來攔截錯誤試試﹕
procedure TINVOICE.SpeedButton1Click(Sender: TObject); var INVO: string; begin IF ComboBox.Text='All_Invoice' Then INVO:='SELECT * FROM [INVOICE] order by INID Desc' ELSE IF ComboBox.Text='InvoiceNumber' Then INVO:='SELECT * FROM [INVOICE] WHERE InvoiceNumber='''+Edit1.Text+''' order by INID Desc' ELSE IF ComboBox.Text='Cntr_No' Then INVO:='SELECT * FROM [INVOICE] WHERE CntrNo like '''+Edit1.Text+''' order by INID Desc' With LJSJK.INVOICE do begin Close; SQL.Clear; SQL.Add(INVO); try Open; except On E:Exception do ShowMessage(E.Message); end; end; end;================================= 有空來瞅瞅我﹗因為我是您的朋友﹐有您真好﹗ ================================
------
忻晟 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |