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

如何取得 order by 的欄位名稱

答題得分者是:Mickey
sfy257000
一般會員


發表:21
回覆:13
積分:6
註冊:2002-07-11

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-09-22 09:09:06 IP:61.222.xxx.xxx 未訂閱
我用 Query 下條件...如: select * from cust order by cuno,cuname 我要如何得知order by 的欄位名稱cuno,cuname ********************* * 只要用心一定成功 * *********************
------
*********************
* 只要用心一定成功 *
*********************
william
版主


發表:66
回覆:2535
積分:3048
註冊:2002-07-11

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-09-22 09:21:47 IP:147.8.xxx.xxx 未訂閱
You need to parse the SQL statement yourself....
channel
尊榮會員


發表:67
回覆:707
積分:854
註冊:2002-05-02

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-09-26 15:02:43 IP:211.21.xxx.xxx 未訂閱
引言: 我用 Query 下條件...如: select * from cust order by cuno,cuname 我要如何得知order by 的欄位名稱cuno,cuname ********************* * 只要用心一定成功 * *********************
var
  I, aLen, aPos: Integer;
begin
  for I := 0 to Query1.SQL.Count - 1 do
  begin
    aPos := Pos('order by ',Query1.SQL.Strings[I]);
    if aPos > 0 then
    begin
      aLen := Length(Query1.SQL.Strings[I]);
      //aPos 9:加九的意思是指Order By 的長度為9
      ShowMessage(Copy(Query1.SQL.Strings[I], aPos 9, aLen-aPos-8))
    end;
  end;
end;
~小弟淺見,參考看看~
------
~小弟淺見,參考看看~
Mickey
版主


發表:77
回覆:1882
積分:1390
註冊:2002-12-11

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-09-26 22:18:25 IP:218.32.xxx.xxx 未訂閱
在 DBCommon.pas 中 有一個 SQLPaser 可以用, 使用方法如下 :
var sql,token: string;
    SQLToken : TSQLToken;
    IsOrderField : boolean;
    Start : PChar;
begin
  sql:='select * from cust order by cuno,cuname';
  SQLToken := stUnknown;
  IsOrderField := False;
  Start := Pchar(sql);
  repeat
    SQLToken := NextSQLToken(Start, Token, SQLToken);
    if IsOrderField and (SQLToken=stFieldName) then showmessage(Token);
    if SQLToken = stOrderBy then IsOrderField := True;
    if IsOrderField and (SQLToken in SQLSections) and
       (SQLToken <> stOrderBy) then IsOrderField := False;
  until SQLToken = stEnd;
end;
系統時間:2024-06-28 19:35:12
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!