用ado的sql语句,如何使用变量当列名? |
尚未結案
|
ffprince
初階會員 發表:66 回覆:62 積分:25 註冊:2003-08-16 發送簡訊給我 |
|
ffprince
初階會員 發表:66 回覆:62 積分:25 註冊:2003-08-16 發送簡訊給我 |
|
Chance36
版主 發表:31 回覆:1033 積分:792 註冊:2002-12-31 發送簡訊給我 |
|
johnny2212
初階會員 發表:34 回覆:65 積分:39 註冊:2003-04-09 發送簡訊給我 |
procedure TForm1.Button1Click(Sender: TObject);
var
aa: String;
begin
aa:='empno';
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('select ' aa);
ADOQuery1.SQL.add('from employee');
ADOQuery1.Open;
//這樣比較容易看的懂 //你也可以寫成這樣
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Text:='select ' aa ' from employee';
ADOQuery1.Open;
end;
|
ffprince
初階會員 發表:66 回覆:62 積分:25 註冊:2003-08-16 發送簡訊給我 |
引言: procedure TForm1.Button1Click(Sender: TObject); var aa: String; begin aa:='empno'; ADOQuery1.SQL.Clear; ADOQuery1.SQL.Add('select ' aa); ADOQuery1.SQL.add('from employee'); ADOQuery1.Open; //這樣比較容易看的懂 //你也可以寫成這樣 ADOQuery1.SQL.Clear; ADOQuery1.SQL.Text:='select ' aa ' from employee'; ADOQuery1.Open; end;请问我这么写有什么错误吗?运行时报错“ORA-00911:无效序列” day:string; day:='nowdate'; Query1.Close; query1.SQL.clear; query1.SQL.Text:='select ' day ' from table where ' day '=1'; query1.ExecSQL; query1.Open; |
Fishman
尊榮會員 發表:120 回覆:1949 積分:2163 註冊:2006-10-28 發送簡訊給我 |
Hi:
day:string; day:='nowdate'; Query1.Close; query1.SQL.clear; query1.SQL.Text:='select ' day ' from table where ' day '=1'; query1.ExecSQL;-->此行似乎是多餘的 query1.Open;-------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman |
terrychen
尊榮會員 發表:90 回覆:794 積分:501 註冊:2003-05-01 發送簡訊給我 |
您好:
day:string;
day:='nowdate';
Query1.Close;
query1.SQL.clear;
query1.SQL.Text:='select '+day+' from table where '+day+'=1';
1.query1.ExecSQL;無回傳直
2.query1.Open;有回傳直
用1就不要用2,反之...
你這裡應適合用2
還有你的nowdate欄位型態是日期ㄇ,如果是' day '=1';要等於日期 ~~應無所住而生其心~~
|
deity
尊榮會員 發表:90 回覆:876 積分:678 註冊:2003-05-09 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |