亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Delphi > 正文

在Delphi中自己建立交叉表

2019-11-18 18:06:02
字體:
來源:轉載
供稿:網友
 

經常在CSDN上查閱名位大俠的文章,得益不少,近期因做一個項目,需要用到交叉表,報表上倒是有,但客戶要求在Grid上能操作,沒有辦法,只好自己寫了一段代碼用于普通查詢到交叉表的實現,不敢獨享,故上傳,望能拋磚引玉,請名位大俠不吝指教。


function CreateTmptab(const AFieldDefs:TFieldDefs):TDataSet;
var
TempTable:TatClientDataSet;
begin
TempTable:=nil;
Result:=nil;
if AFieldDefs<>nil then
begin
    try
        TempTable:=TatClientDataSet.Create(application);
        TempTable.FieldDefs.Assign(AFieldDefs);
        TempTable.CreateDataSet;
        Result:=(TempTable as TDataSet);
    Except
    if TempTable<>nil then
        TempTable.Free;
        Result:=nil;
        raise;
    end
end;
end;
{
SouDataset源數據集
ColField交叉表動態列字段
RowField交叉表行字段
DataField數據字段
}
function GenCrossTable(SouDataset:tdataset;ColField,RowField,DataField:string):tdataset;
var
Vdataset:tdataset;
tmpdataset:tatclientdataset;
DataSource:tdatasource;
tmpstrs:tstrings;
rowval,colval,dataval:string;
i,j:integer;
datatype:TFieldType;
DataSize:integer;
begin
result:=nil;
if (ColField='') or(RowField='')or(DataField='') then
  showmessage('All Field not be NULL!')
else
begin
  if (ColField=RowField)
      or(ColField=DataField)
      or(RowField=DataField) then
    showmessage('All Field not be Equ!')
  else
  if (self.SouDataSet.FieldByName(ColField).DataType=ftString)
    or (self.SouDataSet.FieldByName(ColField).DataType<>ftWideString)
    or (self.SouDataSet.FieldByName(ColField).DataType<>ftFixedChar)
    or (self.SouDataSet.FieldByName(ColField).DataType<>ftMemo)
    or (self.SouDataSet.FieldByName(ColField).DataType<>ftFmtMemo)  then
  begin
  try
    tmpstrs:=tstringlist.Create;
    Vdataset:=SouDataSet;
    Vdataset.First;
    for i:=0 to Vdataset.RecordCount-1 do
    begin
      if (varisnull(SouDataSet.FieldValues[colfield])=false) and (SouDataSet.FieldValues[colfield]<>'') then
        if tmpstrs.IndexOf(SouDataSet.FieldValues[colfield])=-1 then
        begin
          tmpstrs.Add(SouDataSet.FieldValues[colfield]);
        end;
      Vdataset.Next;
    end;
    //生成動態列標題
    tmpdataset:=TClientDataSet.Create(Self);
    tmpdataset.FieldDefs.Add(rowfield,ftstring,50,False);
    for i:=0 to tmpstrs.Count-1 do
    begin
      with tmpdataset.FieldDefs do
      begin
        Add(tmpstrs.Strings[i],ftInteger,0,False);
      end;
    end;
    tmpdataset.FieldDefs.Add('Sum',ftInteger,0,False);
    DataSource:=tdatasource.Create(self);
    DataSource.DataSet:=tmpdataset;
    with DataSource do
    begin
      dataset:=Createtmptab(tmpdataset.FieldDefs);
      dataset.Open;
    end;
    //建立臨時表
    Vdataset.First;
    for i:=0 to Vdataset.RecordCount-1 do
    begin
      rowval:=SouDataSet.fieldbyname(rowfield).AsString;
      colval:=SouDataSet.fieldbyname(colfield).AsString;
      dataval:=SouDataSet.fieldbyname(datafield).AsString;
      if dataval='' then dataval:='0';
      if DataSource.DataSet.Locate(rowfield,rowval,[loPartialKey]) then
      begin
        DataSource.DataSet.Edit;
        DataSource.DataSet.FieldByName(colval).AsString:=dataval;
        DataSource.DataSet.FieldByName('Sum').AsInteger:=
          DataSource.DataSet.FieldByName('Sum').AsInteger+strtoint(dataval);
        DataSource.DataSet.Post;
      end
      else
      begin
        DataSource.DataSet.Append;
        DataSource.DataSet.FieldByName(rowfield).AsString:=rowval;
        for j:=1 to DataSource.DataSet.Fields.Count-1 do
          DataSource.DataSet.Fields[j].AsCurrency:=0;
        DataSource.DataSet.FieldByName(colval).AsString:=dataval;
        DataSource.DataSet.FieldByName('Sum').AsString:=dataval;
        DataSource.DataSet.Post;
      end;
      Vdataset.Next;
    end;
    result:=DataSource.DataSet;
    //生成交叉表數據集
    tmpstrs.Free;
  except
  end;
  end
  else
    showmessage('ColField Must be of Type String!') ;
end;
end;


上一篇:綁架窗體之Delphi版

下一篇:用Delphi制作DLL小結

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩高清电影免费观看完整版| 性金发美女69hd大尺寸| 日韩欧美在线视频| 欧美成人精品激情在线观看| 成人中文字幕+乱码+中文字幕| 亚洲免费影视第一页| 国产一区二区三区在线视频| 欧美极品少妇xxxxⅹ裸体艺术| 欧美日韩一区二区在线播放| 欧美亚洲另类制服自拍| 久久亚洲精品一区| 91久久久久久久久久久| 欧美国产一区二区三区| 福利视频第一区| 国产做受高潮69| 色午夜这里只有精品| 欧美极品少妇xxxxⅹ喷水| 久久精品免费电影| 亚洲一区二区三区sesese| 国产成人精品免高潮在线观看| 国产精品第一页在线| 成人国产亚洲精品a区天堂华泰| 日韩欧美精品免费在线| 欧美大秀在线观看| 日产日韩在线亚洲欧美| 欧美性猛交99久久久久99按摩| 日韩中文字幕在线| 日韩在线中文字| 欧美性感美女h网站在线观看免费| 久久免费视频观看| 久久精品91久久香蕉加勒比| 亚洲另类xxxx| 欧美电影免费观看| 日韩免费高清在线观看| 日韩在线免费视频| 亚洲国产小视频| 国产成人精品国内自产拍免费看| 欧美激情第一页xxx| 国产婷婷成人久久av免费高清| 欧美午夜宅男影院在线观看| 国产伦精品一区二区三区精品视频| 5252色成人免费视频| 国产精品爽爽爽爽爽爽在线观看| 久久人人爽人人爽人人片av高请| 国产精品吴梦梦| 亚洲国产欧美一区二区丝袜黑人| 国产视频精品在线| 欧美成人午夜激情在线| 欧洲成人免费aa| 精品在线欧美视频| 中文字幕av一区中文字幕天堂| 国产精品自产拍在线观看中文| 欧美特级www| 97久久精品视频| 日韩精品免费观看| 九九九热精品免费视频观看网站| 国产日韩精品在线观看| 国产成人综合精品在线| 亚洲色图偷窥自拍| 欧美成人在线免费| 成人午夜一级二级三级| 国产91色在线免费| 亚洲男人天堂九九视频| 97色在线视频| 欧美日韩精品中文字幕| 欧美二区乱c黑人| 欧美精品videosex极品1| 国产69精品99久久久久久宅男| 国产精品青青在线观看爽香蕉| 国产精品99导航| 中文字幕亚洲在线| 午夜精品蜜臀一区二区三区免费| 国产精品va在线播放| 日本在线观看天堂男亚洲| 久久91精品国产91久久久| 38少妇精品导航| 国外成人在线直播| 亚洲国产女人aaa毛片在线| 亚洲成色777777在线观看影院| 6080yy精品一区二区三区| 久久这里有精品| 国产男女猛烈无遮挡91| www.日韩av.com| 亚洲一区二区在线播放| 日韩国产精品亚洲а∨天堂免| 亚洲国产精品电影在线观看| 7777免费精品视频| 日韩在线一区二区三区免费视频| 国产黑人绿帽在线第一区| 亚洲激情视频在线| 久久精品99国产精品酒店日本| 日韩二区三区在线| 欧美性猛交xxxx乱大交蜜桃| 欧美精品一区二区三区国产精品| 国产在线拍揄自揄视频不卡99| 黄网站色欧美视频| 亚洲国产中文字幕久久网| 国产欧美日韩精品丝袜高跟鞋| 久久人人爽人人爽人人片av高清| 国产偷国产偷亚洲清高网站| 亚洲精品在线观看www| 精品香蕉一区二区三区| 久久夜色精品亚洲噜噜国产mv| 国产日本欧美一区二区三区在线| 久久久噜噜噜久久中文字免| 精品五月天久久| 有码中文亚洲精品| 欧美性色视频在线| 国产精品视频在线观看| 久久国产精品首页| 日韩中文字幕欧美| 亚洲乱亚洲乱妇无码| 欧美精品激情在线| 欧美疯狂性受xxxxx另类| 精品亚洲永久免费精品| 欧美成人合集magnet| 日韩av影院在线观看| 亚洲国产成人久久综合一区| 久久久久久久久久国产精品| 久久夜色精品国产| 久久久久久久久国产| 国产精品一区专区欧美日韩| 欧美激情欧美激情在线五月| 一区二区福利视频| 中文字幕欧美亚洲| 亚洲精品一区二区三区不| 欧美激情第三页| 91精品国产综合久久香蕉的用户体验| 日韩精品视频在线播放| 欧美精品久久久久久久久| 亚洲一区二区三区sesese| 国产免费一区视频观看免费| 97av在线视频| 91黑丝在线观看| 亚洲国产精久久久久久久| 欧美色xxxx| 亚洲激情电影中文字幕| 国产成人精品久久| 91精品在线观| 黑人巨大精品欧美一区二区一视频| 亚洲成人网av| 日韩欧美中文免费| 国产美女被下药99| 日韩av一区二区在线| 国产精品69久久| 欧美成人中文字幕| 国产经典一区二区| 精品久久久久久中文字幕一区奶水| 亚洲欧美另类国产| 日韩av高清不卡| 精品福利在线视频| 九色精品免费永久在线| 91老司机精品视频| 欧美丰满少妇xxxxx做受| 国产亚洲精品久久久久动| 欧美大尺度电影在线观看| 欧美夫妻性生活视频| 亚洲日韩中文字幕在线播放| 国产成人精品午夜| 欧美日韩美女在线| 欧美激情喷水视频| 成人在线激情视频| 亚洲美女在线看| 欧美成人在线免费视频|