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

locate該如何改成SQL指令??

尚未結案
amyh54
一般會員


發表:3
回覆:10
積分:2
註冊:2004-04-01

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-04-04 17:03:03 IP:163.28.xxx.xxx 未訂閱
請問一下,我原本是用Locate寫法去搜尋資料, 我現在想用SQL語法去做, 所以增加了ADOQuery1元件, 我該如何把Found:=ClientDataSet1.Locate('電話', VarArrayOf([edtSearch.Text]),[loCaseInsensitive,loPartialKey]); 這段改成SQL指令呢?謝謝! 程式片段如下: ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ClientDataSet1.ApplyUpdates(0); num := edtSearch.Text; time := edtTime.Text; SQL := 'select * from test'; ADOQuery1.Close; ADOQuery1.SQL.Clear; ADOQuery1.SQL.Add(SQL); ADOQuery1.Active := True; Found:=ClientDataSet1.Locate('電話', VarArrayOf([edtSearch.Text]),[loCaseInsensitive,loPartialKey]);
yachanga
資深會員


發表:24
回覆:335
積分:296
註冊:2003-09-27

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-04-04 21:37:19 IP:61.230.xxx.xxx 未訂閱
ClientDataSet1.ApplyUpdates(0); num := edtSearch.Text; time := edtTime.Text; SQL := 'select * from test where 電話 like ''num%'' '; ADOQuery1.Close; ADOQuery1.SQL.Clear; ADOQuery1.SQL.Add(SQL); ADOQuery1.Active := True; 其中 loCaseInsensitive: Key fields and key values are matched without regard to case. loPartialKey: Key values can include only part of the matching key field value; for example, 'HAM' would match both 'HAMM' and 'HAMMER.' ~悠遊法國號~ 發表人 - yachanga 於 2004/04/04 21:39:04
Mickey
版主


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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-04-04 22:19:00 IP:218.32.xxx.xxx 未訂閱
amyh54 你好:    Locate (搜尋) 是於一個 DataSet 中, 找到定位.    一般來說, SQL 中並無此功能, SQL 之 "where" 區段, 是"過濾"條件.    與 "搜尋"...有點不太一樣喔.
amyh54
一般會員


發表:3
回覆:10
積分:2
註冊:2004-04-01

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-04-04 22:28:32 IP:163.28.xxx.xxx 未訂閱
引言: ClientDataSet1.ApplyUpdates(0); num := edtSearch.Text; time := edtTime.Text; SQL := 'select * from test where 電話 like ''num%'' '; ADOQuery1.Close; ADOQuery1.SQL.Clear; ADOQuery1.SQL.Add(SQL); ADOQuery1.Active := True; 其中 loCaseInsensitive: Key fields and key values are matched without regard to case. loPartialKey: Key values can include only part of the matching key field value; for example, 'HAM' would match both 'HAMM' and 'HAMMER.' ~悠遊法國號~ 發表人 - yachanga 於 2004/04/04 21:39:04
嗯嗯^^我試試看 謝謝你
amyh54
一般會員


發表:3
回覆:10
積分:2
註冊:2004-04-01

發送簡訊給我
#5 引用回覆 回覆 發表時間:2004-04-04 22:30:19 IP:163.28.xxx.xxx 未訂閱
引言: amyh54 你好: Locate (搜尋) 是於一個 DataSet 中, 找到定位. 一般來說, SQL 中並無此功能, SQL 之 "where" 區段, 是"過濾"條件. 與 "搜尋"...有點不太一樣喔. < face="Verdana, Arial, Helvetica"> 所以 我一定要用locate嗎 單獨用SQL是沒有作用的喔?? 難怪我剛一直試 都不會移動ㄟ@@ 謝謝你^^
Mickey
版主


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

發送簡訊給我
#6 引用回覆 回覆 發表時間:2004-04-04 22:58:56 IP:218.32.xxx.xxx 未訂閱
SQL 中, 最常用到的就是 "select" 指令, 是取得一個Server端的 Cursor Handle 前端則依據此 Handle, 取出 Data. 如何取出 ? 全取出 ? 需要才取 ? 各種介面(ADO/BDE/DBExpress 等...) 都有其一套複雜的邏輯. 言歸正傳, DataSet.Locate 是屬於前端的功能, 不該,也不適合於後端資料庫.
yachanga
資深會員


發表:24
回覆:335
積分:296
註冊:2003-09-27

發送簡訊給我
#7 引用回覆 回覆 發表時間:2004-04-04 23:00:02 IP:61.230.xxx.xxx 未訂閱
amyh54 你好: 如果是 Filter 功能 就可以用SQL 中 where 替代 恩..Locate 功能仔細想想 SQL 並無適當的SQL對應指令    感謝Mickey熱心的指導 受教了 <>~悠遊法國號~
amyh54
一般會員


發表:3
回覆:10
積分:2
註冊:2004-04-01

發送簡訊給我
#8 引用回覆 回覆 發表時間:2004-04-04 23:07:27 IP:163.28.xxx.xxx 未訂閱
嗯嗯~~~我大概知了 不過我的locate是寫在前端的沒錯 那串程式都是寫在client端的 前端用了DCOM,Clientdataset,datasource,adoQuery這些元件 所以~~~ 搞得很複雜@@ 謝謝你~~~ 我明天會去學校改改看 有問題再上來請教^^
amyh54
一般會員


發表:3
回覆:10
積分:2
註冊:2004-04-01

發送簡訊給我
#9 引用回覆 回覆 發表時間:2004-04-04 23:09:23 IP:163.28.xxx.xxx 未訂閱
嗯嗯^^謝謝你 我明天去學校試^^
Mickey
版主


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

發送簡訊給我
#10 引用回覆 回覆 發表時間:2004-04-04 23:09:59 IP:218.32.xxx.xxx 未訂閱
引言: amyh54 你好: 如果是 Filter 功能 就可以用SQL 中 where 替代 恩..Locate 功能仔細想想 SQL 並無適當的SQL對應指令 感謝Mickey熱心的指導 受教了 < face="Verdana, Arial, Helvetica"> 您客氣了, 討論討論而已, 就算是教與學, 一樣可以相長...這樣的討論風氣...感覺很棒
jieshu
版主


發表:42
回覆:894
積分:745
註冊:2002-04-15

發送簡訊給我
#11 引用回覆 回覆 發表時間:2004-04-05 10:25:35 IP:203.204.xxx.xxx 未訂閱
引言: 前端用了DCOM,Clientdataset,datasource,adoQuery這些元件 所以~~~ 搞得很複雜@@
完全的三層式架構在Client端是不會再用ADOQuery類元件連到主資料庫的,頂多只是用來讀Excel檔案。
人生有夢,逐夢而行。 人若為善,福雖未至,禍已遠離。 人若為惡,禍雖未至,福已遠離。 http://www.coss.com.tw/jieshu/
------
人生有夢,逐夢而行
人若為善,福雖未至,禍已遠離
人若為惡,禍雖未至,福已遠離
http://www.taconet.com.tw/jieshu/
amyh54
一般會員


發表:3
回覆:10
積分:2
註冊:2004-04-01

發送簡訊給我
#12 引用回覆 回覆 發表時間:2004-04-05 12:58:05 IP:210.62.xxx.xxx 未訂閱
引言: 完全的三層式架構在Client端是不會再用ADOQuery類元件連到主資料庫的,頂多只是用來讀Excel檔案。
人生有夢,逐夢而行。 人若為善,福雖未至,禍已遠離。 人若為惡,禍雖未至,福已遠離。 http://www.coss.com.tw/jieshu/
嗯嗯~~~這樣ㄚ 我在試別的做法好了 謝謝你^^
Ktop_Robot
站務副站長


發表:0
回覆:3511
積分:0
註冊:2007-04-17

發送簡訊給我
#13 引用回覆 回覆 發表時間:2007-04-30 13:44:57 IP:000.000.xxx.xxx 未訂閱
提問者您好:


以上回應是否已得到滿意的答覆?


若已得到滿意的答覆,請在一週內結案,否則請在一週內回覆還有什麼未盡事宜,不然,
將由版主(尚無版主之區域將由副站長或站長)自由心證,選擇較合適之解答予以結案處理,
被選上之答題者同樣會有加分獎勵同時發問者將受到扣 1 分的處分。不便之處,請見諒。


有問有答有結案,才能有良性的互動,良好的討論環境需要大家共同維護,感謝您的配合。

------
我是機器人,我不接受簡訊.
系統時間:2024-04-23 17:32:27
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!