zoukankan      html  css  js  c++  java
  • delphi 根据DELTA自动生成SQL语句

    delphi 根据DELTA自动生成SQL语句 上传客户端的CLIENTDATASET.delta到服务器的clientdataset.data,服务端解析clientdataset的数据生成相应的SQL语句。 相对于直接调用datasetprovider.applyupdates()方法提交数据而言,前者的可控性更强,对于某些要求灵活性很强的场合,前者可能是必须的提交方式。

    procedure TBaseService.ApplyUpdates(const Delta: OleVariant; TableName, KeyField: WideString);
    var
      Flag: Boolean;
    begin
      if VarIsNull(Delta) then exit;
      with (FParent as TDataServer2) do
        begin
          cdsDelta.Close;
          cdsDelta.Data := Delta;
          Flag := cdsDelta.FindField('SYS_STATUS') <> nil;
        end; // with
      if Flag then
        InnerApplyUpdates2(TableName, KeyField)
      else
        InnerApplyUpdates(TableName, KeyField);
    end;
     
    procedure TBaseService.InnerApplyUpdates(TableName, KeyField: WideString);
    var
      i: integer;
      s1, s2: string;
      CmdStr: string;
      FieldList: TStringList;
    begin
      with (FParent as TDataServer2) do
        begin
          FieldList := TStringList.Create;
          Connection.GetFieldNames(TableName, FieldList);
          if not cdsDelta.Active then cdsDelta.Open;
          for i := 1 to FieldList.Count do
            if cdsDelta.FindField(FieldList[i - 1]) <> nil then
              cdsDelta.FindField(FieldList[i - 1]).Tag := 1;
          FieldList.Free;
          if cdsDelta.RecordCount > 0 then
            begin
              cdsDelta.First;
              s1 := '';
              s2 := '';
              while not cdsDelta.Eof do
                begin
                  CmdStr := '';
                  case cdsDelta.UpdateStatus of
                    usUnmodified:
                      begin
                        s2 := VarToSql(cdsDelta[KeyField]);
                      end;
                    usModified:
                      begin
                        s1 := '';
                        for i := 1 to cdsDelta.FieldCount do
                          if (not cdsDelta.Fields[i - 1].IsNull) and (cdsDelta.Fields[i - 1].Tag = 1) then
                            begin
                              if s1 = '' then
                                s1 := Trim(cdsDelta.Fields[i - 1].FieldName) + ' = ' + VarToSql(cdsDelta.Fields[i - 1].Value)
                              else
                                s1 := s1 + ',' + Trim(cdsDelta.Fields[i - 1].FieldName) + ' = ' + VarToSql(cdsDelta.Fields[i - 1].Value);
                            end;
                        if s1 <> '' then
                          begin
                            CmdStr := 'Update ' + TableName + ' Set ' + s1 + ' Where ' + KeyField + ' = ' + s2;
                          end;
                      end;
                    usInserted:
                      begin
                        s1 := '';
                        s2 := '';
                        for i := 1 to cdsDelta.FieldCount do
                          if (not cdsDelta.Fields[i - 1].IsNull) and (cdsDelta.Fields[i - 1].Tag = 1) then
                            begin
                              if s1 = '' then
                                begin
                                  s1 := Trim(cdsDelta.Fields[i - 1].FieldName);
                                  s2 := VarToSql(cdsDelta.Fields[i - 1].Value);
                                end
                              else
                                begin
                                  s1 := s1 + ',' + Trim(cdsDelta.Fields[i - 1].FieldName);
                                  s2 := s2 + ',' + VarToSql(cdsDelta.Fields[i - 1].Value);
                                end;
                            end;
                        if s1 <> '' then
                          begin
                            CmdStr := 'Insert into ' + TableName + '(' + s1 + ') Values (' + s2 + ')';
                          end;
                      end;
                    usDeleted:
                      begin
                        s2 := VarToSql(cdsDelta[KeyField]);
                        CmdStr := 'Delete ' + TableName + ' Where ' + KeyField + ' = ' + s2;
                      end;
                  end;
                  if CmdStr <> '' then Cmd.Execute(CmdStr);
                  cdsDelta.Next;
                end;
              cdsDelta.First;
              cdsDelta.EmptyDataSet;
              cdsDelta.Close;
            end;
        end;
    end;
     
    好的代码像粥一样,都是用时间熬出来的
  • 相关阅读:
    前路漫长
    OEL6 /boot分区删除恢复
    区块链:剖析工作量证明
    【转】区块链:Schnoor签名究竟是什么
    使用 Hyperledger Fabric 开展私密交易
    Sovrin:技术落地可期,但推广难度较高
    白硕:区块链技术与数据隐私(附视频)
    从入门到精通零知识证明与zkSNARK
    区块链安全:匿名性以及隐私性
    朋友去面试Python工程师,又带回来几道基础题,Python面试题No10
  • 原文地址:https://www.cnblogs.com/jijm123/p/13695199.html
Copyright © 2011-2022 走看看