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

Delete的問題

答題得分者是:christie
fly2100kimo
一般會員


發表:2
回覆:1
積分:0
註冊:2007-10-04

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-10-18 00:15:43 IP:220.133.xxx.xxx 訂閱
各位好:
小弟有一個問題想請教;假如資料表的資料有1000筆來說好了。可透過ADOQuery1->RecordCount得知!
DELETE的語法該如何下,以達到可以保留最後新增的100筆資料。把前面多餘的900筆資料一次刪除呢?

謝謝


agogorz
初階會員


發表:9
回覆:34
積分:28
註冊:2005-04-09

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-10-18 10:10:30 IP:203.75.xxx.xxx 訂閱
delete from table where rownum < ado.recordcount -100
ado.recordcount -100要由程式算出後塞進sql裡
fly2100kimo
一般會員


發表:2
回覆:1
積分:0
註冊:2007-10-04

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-10-18 13:33:24 IP:220.130.xxx.xxx 訂閱
謝謝 agogorz的回覆,不過小弟我照著方法實作。會出現 參數rownum,沒有預設值
<!--StartFragment-->
       <!--StartFragment-->
      ADOQuery1->Active=true;
AnsiString Temp2 = ADOQuery1->RecordCount ; AnsiString Temp3 = Edit1->Text.ToInt(); ADOQuery1->Close(); ADOQuery1->SQL->Clear(); AnsiString Temp = "DELETE FROM ErrorTable WHERE ROWNUM >'" Temp3 "'" ; ADOQuery1->SQL->Add(Temp); ADOQuery1->ExecSQL();

===================引 用 agogorz 文 章===================
delete from table where rownum < ado.recordcount -100
ado.recordcount -100要由程式算出後塞進sql裡
christie
資深會員


發表:30
回覆:299
積分:475
註冊:2005-03-25

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-10-18 14:29:26 IP:203.73.xxx.xxx 未訂閱
請留意
AnsiString
Temp = "DELETE FROM ErrorTable WHERE ROWNUM <'" Temp3 "'" ;


ROWNUM in Oracle SQL

rownum is a pseudo column. It numbers the records in a result set.
The first record that meets the where criteria in a select statement
is given rownum=1, and every subsequent record meeting that same
criteria increases rownum.

After issuing a select statement, one of the last steps that oracle
does is to assign an increasing (starting with 1, increased by 1)
number to each row returned.


------
What do we live for if not to make life less difficult for each other?
agogorz
初階會員


發表:9
回覆:34
積分:28
註冊:2005-04-09

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-10-18 16:17:49 IP:59.124.xxx.xxx 訂閱


編輯記錄
agogorz 重新編輯於 2007-10-23 11:30:33, 註解 無‧
系統時間:2024-04-20 12:40:47
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!