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

型態轉換問題

尚未結案
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#1 引用回覆 回覆 發表時間:2002-12-09 16:00:37 IP:211.22.xxx.xxx 未訂閱
我將 Query 查詢出來的結果放到某個 array 中 再將 這個 array assign 給 QuickRep 的 DataSet 然後出現以下型態不相容的訊息 但是 QuickRep2.DataSet 不是本來就可以是 某個Query 的結果嗎 ??? type TCach_Buf = array [1..8] of TQuery; theCach_Buf : TCach_Buf; theCach_Buf[i] := DataModule64.Query1; Form37.QuickRep2.DataSet := theCach_Buf; ==> Incompatible types: 'TDataSet' and 'TCach_Buf'
william
版主


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2002-12-09 16:06:18 IP:147.8.xxx.xxx 未訂閱
Form37.QuickRep2.DataSet := theCach_Buf[i]; Type mismatch.
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#3 引用回覆 回覆 發表時間:2002-12-09 16:44:29 IP:211.22.xxx.xxx 未訂閱
若是改成 Form37.QuickRep2.DataSet := theCach_Buf[0]; 則出現 constant expression violates subrange bounds
william
版主


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

發送簡訊給我
#4 引用回覆 回覆 發表時間:2002-12-09 16:49:09 IP:147.8.xxx.xxx 未訂閱
引言:若是改成 TCach_Buf = array [1..8] of TQuery; Form37.QuickRep2.DataSet := theCach_Buf[0]; 則出現 constant expression violates subrange bounds
So 0 is out of range.
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#5 引用回覆 回覆 發表時間:2002-12-09 17:12:54 IP:211.22.xxx.xxx 未訂閱
但在 Object Inspect 中可以發現 QuickRep2.DataSet 可以是 Query1 啊 那應該是代表整個 Query1 的所有 record 吧 ! 我一開始是把 Query1 的 record 一個一個 assign 給 theCach_Buf[i]; 所以 theCach_Buf 不就代表整個 Query1 嗎 ? 為什麼不能把 theCach_Buf assign 給 QuickRep2.DataSet 呢 ? 這與 把整個 Query1 assign 給 QuickRep2.DataSet 不是相同的道理嗎 ?
william
版主


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

發送簡訊給我
#6 引用回覆 回覆 發表時間:2002-12-09 17:38:56 IP:147.8.xxx.xxx 未訂閱
引言:theCach_Buf[i] := DataModule64.Query1;
Assign the address (a 4 byte pointer) of object Query1 to theCach_Bug[i]. Maybe you have some misunderstanding here?
andersonhsieh
版主


發表:33
回覆:531
積分:439
註冊:2002-06-10

發送簡訊給我
#7 引用回覆 回覆 發表時間:2002-12-09 17:52:40 IP:211.20.xxx.xxx 未訂閱
DATASET不等於ARRAY,DATASET是一個OBJECT和ARRAY是不同的你不可以將ARRAY ASSIGN給一個DATASET型態的變數 @@~~飛翔在天際的精靈~~@@
------
@@~~飛翔在天際的精靈~~@@
ccchen
版主


發表:61
回覆:940
積分:1394
註冊:2002-04-15

發送簡訊給我
#8 引用回覆 回覆 發表時間:2002-12-09 21:44:22 IP:203.217.xxx.xxx 未訂閱
我嘗試依你的程式解釋給你看, 相信不是你的原意 TCach_Buf = array [1..8] of TQuery; TCach_Buf定義一個array共8個參考指標(1到8不含0), 每一參考指標均可指向一個TQuery(不是Record buffer) theCach_Buf : TCach_Buf; theCach_Buf意義同上 theCach_Buf[i] := DataModule64.Query1; i尚未定義, 假設i=0則代表第一個參考指標指向DataModule64.Query1 (是query不是record buffer) Form37.QuickRep2.DataSet := theCach_Buf; 將一個array assign給一個DataSet->當然錯了 實際上你可以直接用 Form37.QuickRep2.DataSet := DataModule64.Query1 發表人 - ccchen 於 2002/12/09 21:46:25
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#9 引用回覆 回覆 發表時間:2002-12-10 08:58:48 IP:211.22.xxx.xxx 未訂閱
我的目的本來是想將 Query 的結果以每 8 筆資料送到 QuickRep 列印 所以才會以 for loop 一筆一筆將 data assign 到一個 array 中 然後再把這個 array 內的資料 assign 給 QuickRep2.DataSet 以便確定 QuickRep2.DataSet 每次都只能有 8 筆資料 若是直接寫成 Form37.QuickRep2.DataSet := DataModule64.Query1 那就不能保證 QuickRep2.DataSet 只有8 筆了啊 !
ccchen
版主


發表:61
回覆:940
積分:1394
註冊:2002-04-15

發送簡訊給我
#10 引用回覆 回覆 發表時間:2002-12-10 09:16:47 IP:61.219.xxx.xxx 未訂閱
你仍可以用Form37.QuickRep2.DataSet := DataModule64.Query1 然後在Quick Report之Event中處理, 如BeforePrint,或onNeeddata,onStartPage等
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#11 引用回覆 回覆 發表時間:2002-12-10 09:44:18 IP:211.22.xxx.xxx 未訂閱
您提議的方式我之前也有試過, 但發生以下的問題, 所以才會想用 buffer 的方式自行處理, 以下是用 event 所發生的問題 以下是我的報表的格式 PageHeader ==> 每頁的開頭都會印 GroupHeader ==> 每個 Group 開頭才會印 Detail GroupFooter ==> Group 結束時才會印 我希望每個 Group 結束都要換頁, 且若一個 Group 的 Detail 每 8 行也要換頁, 以下是我目前的做法 設一個變數 recordNum QuickRep1BeforePrint ==> recordCount:=0; Detail AfterPrint ==> recordCount := recordCount 1; if recordCount mod 8 = 0 then begin QuickRep1.NewPage; end; Group AfterPrint ==> if recordCount mod 8 <> 0 then QuickRep1.NewPage; recordCount:=0; 現在發現一個問題 每個 Detail 印完後即使剛好等於 8 行而有換頁, 程式也不會發現這個 Group 是否剛好結束了 若這個 Group 尚未結束, 則換頁後繼續印 Detail record, 且因 Group 尚末結束 所以這一頁的 PageHeader 上的資料仍屬於與上一頁相同的 Group 但若這個 Group 剛好結束, 而你的換頁是在 Detail 印完後馬上換, 等偵測到 Group 結束時卻沒換頁 這時 新一頁的 PageHeader 上的資料仍屬於與上一頁相同的 Group, 但是 Detail record 印出的卻己是下一個 Group 的資料了, 所以看起來就不對 我希望我的報表每頁開頭都會印出這張驗收單的驗收單號 所以驗收單號這個資料必須放在 PageHeader 但這樣當遇到 Group 剛好8 行而在第 8 行換頁時, 因尚未偵測到 Group 己結束, 所以下一頁即使 GroupHeader 和 Detail 都己是新的 Group, 但 PageHeader 仍是舊的 Group 因為 GroupHeader 才是一個Group 的起點 請問各位還有更好的方法嗎 ?
hahalin
版主


發表:295
回覆:1698
積分:823
註冊:2002-04-14

發送簡訊給我
#12 引用回覆 回覆 發表時間:2002-12-11 00:30:27 IP:203.203.xxx.xxx 未訂閱
兩個建議 1.多加一個group,來源欄位是單號。 2.Crystal Report在處理Group這一段還不錯,如果預算夠的話, 它倒是蠻好用的,跟Quick Report比起來。
william
版主


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

發送簡訊給我
#13 引用回覆 回覆 發表時間:2002-12-11 09:21:53 IP:147.8.xxx.xxx 未訂閱
I have not used QuickReport before, but if you want to create datasets returning 8 rows, here are some suggestion: 1) use Filter on the dataset if you can determine seperate chunk of 8 records according to existing fields 2) use ClientDataSet (i.e. memory table) and fill them as needed
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#14 引用回覆 回覆 發表時間:2002-12-11 16:02:12 IP:211.22.xxx.xxx 未訂閱
為什麼要多加一個 Group 呢 ??? 不太明白 ! 可否請 hahalin 兄解釋詳細一點呢 ? thanks !!
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#15 引用回覆 回覆 發表時間:2002-12-12 16:20:20 IP:211.22.xxx.xxx 未訂閱
請問 ClientDataSet 不是要先給 ClientDataSet1.CommandText 然後才open ClientDataSet 嗎 ? 我只是要把 Query1 的某部分資料 assign 到一個 暫時的 dataset 所以不會給定 ClientDataSet1.CommandText 如此一來 ClientDataSet1 就是一個 closed dataset 了啊 !! 或者是我沒弄清楚 ClientDataSet 的用法呢 ??
william
版主


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

發送簡訊給我
#16 引用回覆 回覆 發表時間:2002-12-12 16:37:02 IP:147.8.xxx.xxx 未訂閱
1) create NEW fields inside the IDE for the ClientDataSet (i.e. create the table structure), double click on the vcl, add new field... 2) call CreateDataSet to create the dataset actually 3) fill in the ClientDataSet
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#17 引用回覆 回覆 發表時間:2002-12-12 17:28:32 IP:211.22.xxx.xxx 未訂閱
我的 ClientDataSet1 只有一個 record 當我執行 ClientDataSet1.Next; 並沒有錯誤訊息出現 但到最後, ClientDataSet1 都只有一個 record 其內容就是最後一次 assign 給它的值 請問是什麼地方出錯了嗎 ? thanks !
william
版主


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

發送簡訊給我
#18 引用回覆 回覆 發表時間:2002-12-12 17:36:02 IP:147.8.xxx.xxx 未訂閱
Forget to call the First method to rewind the cursor for the client dataset 
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#19 引用回覆 回覆 發表時間:2002-12-13 08:57:38 IP:211.22.xxx.xxx 未訂閱
I did call the First method ! the following is my code ! sqlCommand := 'select * from co_in'; Query1.SQL.Clear; Query1.SQL.ADD(sqlCommand); Query1.Open; Query1.First; ClientDataSet1.CreateDataSet; ClientDataSet1.First; ShowMessage('ok'); while not Query1.Eof do begin for i := 1 to 8 do begin if not Query1.Eof then begin for j := 1 to Query1.FieldCount do begin ClientDataSet1.Edit; ClientDataSet1.Fields[j-1].AsString := Query1.Fields[j-1].AsString; ClientDataSet1.Post; ShowMessage('ok'); end; Query1.Next; ClientDataSet1.Next; end; end; end; ShowMessage(IntToStr(ClientDataSet1.RecordCount));
william
版主


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

發送簡訊給我
#20 引用回覆 回覆 發表時間:2002-12-13 09:13:34 IP:147.8.xxx.xxx 未訂閱
引言: I did call the First method ! the following is my code !
sqlCommand := 'select * from co_in';
   Query1.SQL.Clear;
   Query1.SQL.ADD(sqlCommand);
   Query1.Open;       Query1.First;
   ClientDataSet1.CreateDataSet;
   ClientDataSet1.First;
   ShowMessage('ok');
   while not Query1.Eof do
   begin
     for i := 1 to 8 do
     begin
      if not Query1.Eof then
      begin
        ClientDataSet1.Insert;
        for j := 1 to Query1.FieldCount do
        begin
       ClientDataSet1.Fields[j-1].AsString := Query1.Fields[j-1].AsString;
        end;
       ClientDataSet1.Post;
        Query1.Next;
        ClientDataSet1.Next;
      end;
     end;
   end;
   ShowMessage(IntToStr(ClientDataSet1.RecordCount));
I think you should have used Insert to insert a new record.
hahalin
版主


發表:295
回覆:1698
積分:823
註冊:2002-04-14

發送簡訊給我
#21 引用回覆 回覆 發表時間:2002-12-15 10:00:24 IP:203.203.xxx.xxx 未訂閱
引言: 為什麼要多加一個 Group 呢 ??? 不太明白 ! 可否請 hahalin 兄解釋詳細一點呢 ? thanks !!
sorry,這麼久回應,因為以前有遇過同樣的問題,客戶要求出貨單表身每十筆 跳頁,那個case用Crystal Report作報表,說說實作過程希望能有幫助, 1.第一個Group用表頭單號欄位(以下稱為gp1), 第二個group用表身的產品編號欄位(以下稱為gp2)。 2.設定gp1的GroupHead每頁顯示,單號變換後跳頁。 3.在Detail區段新增一個系統變數,Deatail每增加一列加1。 4.以您的八筆紀錄跳頁為例,在gp2的GroupFooter判斷系統變數是否到達 八,到達後跳頁並歸零。 萬流歸宗,工具雖然不同,原理是一樣的。 有一個比較"樸實"的做法,不會跟報表工具粘得太緊, 篩選出要列印的區間資料後,由程式控制在表身的資料集 新增一個欄位,填入流水號,然後在QuickReport的相關事件 去判斷除以八是否整除,可以整除就跳頁。 小小的建議,先畫好設計藍圖,不要急著蓋房子, 如果已經蓋好的房子怪怪的,試著拆掉重建, 也許會很不捨,但重建後的成果一定很不錯。 寫報表我常自己先模擬一遍,把自己當成印表機在 腦海裡面印一次再去排,這個方法很"樸實",不過比較能 十拿九穩。
hahalin
版主


發表:295
回覆:1698
積分:823
註冊:2002-04-14

發送簡訊給我
#22 引用回覆 回覆 發表時間:2002-12-15 10:02:41 IP:203.203.xxx.xxx 未訂閱
補充說明,在gp1的單號欄位變換後,也要將列印detail的變數 歸為零。
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#23 引用回覆 回覆 發表時間:2002-12-17 10:41:33 IP:211.22.xxx.xxx 未訂閱
請問 設定gp1的GroupHead每頁顯示 要如何設呢 ? 好像沒有這樣的屬性吧 要設成每頁顯示不是要用 PageHeader 嗎 ? 這樣就會造成每頁的 PageHeader 和 GroupHeader 的內容不能同步啊 ! 謝謝您的回答 !
hahalin
版主


發表:295
回覆:1698
積分:823
註冊:2002-04-14

發送簡訊給我
#24 引用回覆 回覆 發表時間:2002-12-17 12:11:25 IP:210.243.xxx.xxx 未訂閱
TQRGroup.ReprintOnNewPage property ReprintOnNewPage : Boolean Description If ReprintOnNewPage is True the group header will be reprinted at the top of every page if a group spans more than one page. ReprintOnNewPage is False by default. --------------------------------------------------------------------- good mood,good code. work hard and smart......
系統時間:2024-05-05 17:21:40
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!