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

三層式DBGRID排序的問題

尚未結案
redjeff
一般會員


發表:12
回覆:16
積分:10
註冊:2006-07-06

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-06-08 08:52:24 IP:59.125.xxx.xxx 訂閱
有先去看過文前的文章,有提到排序亂掉的問題,有照著試,但是會出現問題,不曉得是不是因為我是用MASTER、DETAIL的方式,所以現在不曉得該從哪裡去著手,才可以讓我的DETAIL排序不會亂掉,SQL語法裡有做ORDER BY,但好像沒有用~~~~~

例:
A1
A2
A3
B1
B2
B3
照道理應該這樣排,但是會變成亂排
A1
A2
B3
B2
A3
B1
pedro
尊榮會員


發表:152
回覆:1177
積分:865
註冊:2002-06-12

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-06-08 09:09:32 IP:60.248.xxx.xxx 未訂閱
你語法貼出來看看吧,光是猜,猜不到
pcplayer99
尊榮會員


發表:142
回覆:740
積分:591
註冊:2003-01-21

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-06-08 21:30:03 IP:59.40.xxx.xxx 訂閱
详细描述你是怎么做的,你想得到什么效果,实际得到什么结果。

你不说得仔细点,别人想帮你也没办法下手。
redjeff
一般會員


發表:12
回覆:16
積分:10
註冊:2006-07-06

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-06-13 08:14:12 IP:59.125.xxx.xxx 訂閱
master-detail的作法
detail的master_source:='DataSource_Main';
detail的master_fields:='M_ID';
detail的indexFieldNames:='ID';
DETAIL的設定只有這裡,然後就是一般的SQL語法而已
'SELECT * FROM TEST ORDER BY TE_NO'
但是不曉得為什麼DETAIL的排序都會亂掉
danny
版主


發表:100
回覆:522
積分:595
註冊:2002-03-11

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-06-15 16:17:06 IP:211.76.xxx.xxx 訂閱
DETAIL 的SQL語法 應該不只 'SELECT * FROM TEST ORDER BY TE_NO' 這樣吧?
應該是 SELECT * FROM TEST WHERE RELATION_FIELD = :RELATION_FIELD ORDER BY TE_NO
TE_NO 是你上面的資料 A1, A2 .... 的欄位名吧 ?

===================引 用 redjeff 文 章===================
master-detail的作法
detail的master_source:='DataSource_Main';
detail的master_fields:='M_ID';
detail的indexFieldNames:='ID';
DETAIL的設定只有這裡,然後就是一般的SQL語法而已
'SELECT * FROM TEST ORDER BY TE_NO'
但是不曉得為什麼DETAIL的排序都會亂掉
------
將問題盡快結案也是一種禮貌!
redjeff
一般會員


發表:12
回覆:16
積分:10
註冊:2006-07-06

發送簡訊給我
#6 引用回覆 回覆 發表時間:2007-06-16 08:22:30 IP:59.125.xxx.xxx 訂閱
版大:不太懂意思耶?我的master-detail的用法都是那樣子,在detail的部份用master的key值去做設定,這樣子就可以做到master-detail的方式了,不曉得為什麼還要加上"WHERE RELATION_FIELD = :RELATION_FIELD "這段的用意?TEXT_NO是我detail要做排序的那個table的欄位名,和master沒有關係
ex:Master-SQL:=Select * From AA;
Detail-SQL:=Select * From BB Order by B_NO;
Detail的clientdataset_detail的設定:
detail的master_source:='DataSource_Main';
detail的master_fields:='A_ID';
detail的indexFieldNames:='B_A_ID';

PS.如果有說不清楚的地方,麻煩說一下,我是真的很想解決這個問題,否則排序的資料時候都是亂的

===================引 用 danny 文 章===================
DETAIL 的SQL語法 應該不只 'SELECT * FROM TEST ORDER BY TE_NO' 這樣吧?
應該是 SELECT * FROM TEST WHERE RELATION_FIELD = :RELATION_FIELD ORDER BY TE_NO
TE_NO 是你上面的資料 A1, A2 .... 的欄位名吧 ?

===================引 用 redjeff 文 章===================
master-detail的作法
detail的master_source:='DataSource_Main';
detail的master_fields:='M_ID';
detail的indexFieldNames:='ID';
DETAIL的設定只有這裡,然後就是一般的SQL語法而已
'SELECT * FROM TEST ORDER BY TE_NO'
但是不曉得為什麼DETAIL的排序都會亂掉
redjeff
一般會員


發表:12
回覆:16
積分:10
註冊:2006-07-06

發送簡訊給我
#7 引用回覆 回覆 發表時間:2007-06-26 13:02:32 IP:59.125.xxx.xxx 訂閱
===================引 用 redjeff 文 章===================
master-detail的作法
detail的master_source:='DataSource_Main';
detail的master_fields:='M_ID';
detail的indexFieldNames:='ID;

各位 大大:
關於小弟的這個問題,看了很多篇文章,想說會不會是master-detail的設定方式造成的,也看了很多的文章在於master-detail的設定,方法有好幾種,我的設定方法也是其中一種,所以沒什麼問題,但排序還是會亂掉,我就在detail的clientdataset_detail裡的IndexFieldNames裡加上要排序的欄位,排序的問題就解決了,操作也OK,目前就等user看有沒有發生什麼問題了

master-detail的作法
detail的master_source:='DataSource_Main';
detail的master_fields:='M_ID';
detail的indexFieldNames:='ID;D_NAME;D_ADDRESS';(要排序的欄位)
系統時間:2017-12-16 13:07:27
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!