USEGEAR

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

一次得到多个数据集

复制代码
function GetDataSetsByJson(SQL_Statement : string) : TFDJSONDataSets; //得到多个数据集 server
{SQL_Statement格式 'Name' : '名称','CommandText':'SQL语句' } var jo : TJSONObject; jp : TJSONPair; i : Integer; Arr: TArr<TFDQuery>; begin {$REGION '一次得到多个数据集'} jo := TJSONObject.ParseJSONValue(Trim(SQL_Statement),True) as TJSONObject; if not Assigned(jo) then Result := nil; try Result := TFDJSONDataSets.Create; Setlength(Arr,jo.Count); for i := 0 to jo.Count - 1 do begin jp := jo.Pairs[i]; Arr[i] := TFDQuery.Create(Self); Arr[i].Connection := FDConnection1; Arr[i].SQL.Clear; Arr[i].SQL.Add(jp.JsonValue.Value); Arr[i].open; TFDJSONDataSetsWriter.ListAdd(Result,jp.JsonString.Value,Arr[i]); end; finally jo.Free; end; {$ENDREGION} end;
复制代码

 调用

复制代码
function TDM.getTables_Json(ArraySQL: array of string; aFDMemTables: array of TFDMemTable) : Boolean; //client
var
  aServer: TUsegearClient;
  LDataSetList: TFDJSONDataSets;
  aDataSet: TFDAdaptedDataSet;
  jp : TJSONPair;
  jo : TJSONObject;
  i,j : Integer;
begin
{$REGION '一次得到多个数据集'}
  Result := False;
  if (Length(arraySQL) <> Length(aFDMemTables)) then
    begin
      raise Exception.Create('数组数不一致,请检查');
      Exit
    end;
    aServer := TUsegearClient.Create(DSRestConnection1);
    try
      jo := TJSONObject.Create;
      for I := Low(ArraySQL) to High(ArraySQL) do    //准备sql statement
        begin
          jp := TJSONPair.Create('T'+ i.ToString,ArraySQL[i]);
          jo.AddPair(jp);
        end;
      try
        LDataSetList := aServer.GetDataSetsByJson(jo.ToString);
        ShowMessage(TFDJSONDataSetsReader.GetListCount(LDataSetList).ToString);
        j := TFDJSONDataSetsReader.GetListCount(LDataSetList);
        for I := 0 to j - 1 do
          begin
            aDataSet := TFDJSONDataSetsReader.GetListValueByName(LDataSetList, 'T'+ i.ToString);
            aFDMemTables[i].Close;
            aFDMemTables[i].AppendData(aDataSet);
          end;
        Result := True;
      except
        Result := False;
      end;
    finally
      jo.Free;
      aServer.Free;
    end;
{$ENDREGION}
end;
复制代码
  if ClientDMUnit.Dm.getTables_Json(['select * from ProductInfo','select * from ProductParams'],[u3FDMemTable,u2FDMemTable]) then //这里在程序中调用
    begin
       u3FDMemTable.Open;
       u2FDMemTable.Open;
    end;

 

posted on   USEGEAR  阅读(210)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
历史上的今天:
2016-01-03 树莓派2交叉编译环境
点击右上角即可分享
微信分享提示