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

如何抓取資料庫的資料

答題得分者是:scotthsiao
tea15
初階會員


發表:64
回覆:72
積分:27
註冊:2005-06-15

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-09-23 13:10:17 IP:220.130.xxx.xxx 未訂閱
你們好, 我要如何從edit1新增資料進DBGrid內,且要判斷是否會重覆.. 要怎麼寫呢?
scotthsiao
高階會員


發表:13
回覆:324
積分:147
註冊:2005-02-01

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-09-23 13:40:45 IP:211.74.xxx.xxx 未訂閱
在"新增"的按鈕上寫檢驗程式 : 先檢查存不存在,如果不存在則新增。     
if not Query1.Locate('no', Edit.Text, []) then
begin
   Query1.Append;
   Query1.FieldByanme('no').AsString:= Edit1.Text;
   Query1.Post;    end;
 
cashxin2002
版主


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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-09-23 14:39:05 IP:202.62.xxx.xxx 未訂閱
您好﹗    如果是DBGrid1元件是不允許使用者更改的話﹐程式碼就比較單純﹕
begin
  if Not ADOQuery1.Locate('欄位名稱', Edit1.Text, [loCaseInsensitive]) then
    begin
      ADOQuery1.Insert;
      ADOQuery1.FieldByName('欄位名稱').AsString := Edit1.Text;
      ADOQuery1.Post;
    end
  else
    begin
      ShowMessage('資料重复﹗');
      Abort;
    end;
end;
如果DBGrid1是允許使用者更改的﹐還需要判斷ADOQuery1元件的State屬性值是在dsEdit狀態還是dsInsert狀態﹐因為不同的狀態資料集元件Locate的回傳值可能不一樣﹐如下連接中有描述一些相關的程式碼﹐您也可在站內使用查詢功能找找看﹐印象中有蠻多的﹕ http://delphi.ktop.com.tw/topic.php?TOPIC_ID=44779 ================================= 有空來瞅瞅我﹗因為我是您的朋友﹐有您真好﹗ ================================ 發表人 - cashxin2002 於 2005/09/23 15:20:05
------
忻晟
系統時間:2024-11-22 11:39:53
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!