全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:808
推到 Plurk!
推到 Facebook!

請問如下的程式碼錯在哪裡?如何才正確?

答題得分者是:cashxin2002
BIG-ROM
初階會員


發表:94
回覆:91
積分:37
註冊:2005-04-16

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-05-14 03:46:07 IP:219.130.xxx.xxx 未訂閱
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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-05-14 04:53:17 IP:60.248.xxx.xxx 未訂閱
 
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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-05-14 09:08:17 IP:202.47.xxx.xxx 未訂閱
您好﹗
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

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-05-14 13:20:55 IP:219.130.xxx.xxx 未訂閱
感謝兩位先進的回復,但問題還是沒有改善哦    寫程序——新問題會接踵而來!
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-05-14 14:16:53 IP:202.47.xxx.xxx 未訂閱
您好﹗    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

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-05-14 14:38:42 IP:61.223.xxx.xxx 未訂閱
select 請用 open inset , update ,delete 才用 ExecSQL;
Arlung Miao
初階會員


發表:9
回覆:44
積分:25
註冊:2004-08-25

發送簡訊給我
#7 引用回覆 回覆 發表時間:2005-05-14 15:43:15 IP:61.235.xxx.xxx 未訂閱
朋友(BIG-ROM): 我想,從你提供的信息來看,可能變量INVO中根本就沒有被賦值,也就是說你的Combobox中的Text屬性並不是你的程式中包含的這三個(這有可能是你在Coding時的筆誤)。 所以,請做如下的測試:在語句SQL.Add(INVO);前加上ShowMessage(INVO),看看INVO中具體的值是什麽。
BIG-ROM
初階會員


發表:94
回覆:91
積分:37
註冊:2005-04-16

發送簡訊給我
#8 引用回覆 回覆 發表時間:2005-05-14 19:30:14 IP:220.110.xxx.xxx 未訂閱
您好,按方法測試也是相同的錯誤信息.    
引言: 朋友(BIG-ROM): 我想,從你提供的信息來看,可能變量INVO中根本就沒有被賦值,也就是說你的Combobox中的Text屬性並不是你的程式中包含的這三個(這有可能是你在Coding時的筆誤)。 所以,請做如下的測試:在語句SQL.Add(INVO);前加上ShowMessage(INVO),看看INVO中具體的值是什麽。
寫程序——新問題會接踵而來!
BIG-ROM
初階會員


發表:94
回覆:91
積分:37
註冊:2005-04-16

發送簡訊給我
#9 引用回覆 回覆 發表時間:2005-05-14 19:35:48 IP:220.110.xxx.xxx 未訂閱
您好。 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

發送簡訊給我
#10 引用回覆 回覆 發表時間:2005-05-14 20:26:34 IP:219.134.xxx.xxx 未訂閱
朋友, 請問你有沒有把Show出來的SQL直接在其他地方執行一下,看看語法有無錯誤。另外,請把你用ShowMessage顯示出來的SQL發表出來給大家看看好嗎?還要説明一下你使用的數據庫是什麽。
BIG-ROM
初階會員


發表:94
回覆:91
積分:37
註冊:2005-04-16

發送簡訊給我
#11 引用回覆 回覆 發表時間:2005-05-16 02:55:16 IP:210.105.xxx.xxx 未訂閱
參數沒有傳遞到導致無法執行查詢,ComboBox元件的正確用法能否說明一下?    寫程序——新問題會接踵而來!
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#12 引用回覆 回覆 發表時間:2005-05-16 09:02:55 IP:202.47.xxx.xxx 未訂閱
您好﹗    用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;
================================= 有空來瞅瞅我﹗因為我是您的朋友﹐有您真好﹗ ================================
------
忻晟
系統時間:2024-07-01 0:02:04
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!