时间:2021-07-01 10:21:17 帮助过:2人阅读
Delphi:
//把整个表的表字段传到PG中Array结构的string中,当然也可以挑选字段来传,不用的字段,直接增加个","就行. function DataSeRecordToArrayString(ACds: TDataSet): string; var I: Integer; sRecord: string; begin for I := 0 to ACds.FieldCount - 1 do begin if ACds.Fields[I].IsNull then Result := Result + ‘,‘ else begin sRecord := ACds.Fields[I].AsString; if ACds.Fields[I].DataType in [ftBlob, ftObject, ftDataSet, ftGraphic] then Result := Result + ‘,‘ + sRecord else begin
//处理转义字符 如果是正常文本 可以注释掉以加速
if sRecord.contains(‘"‘) then sRecord := sRecord.Replace(‘"‘, ‘\"\"‘, [rfReplaceAll]); if sRecord.IndexOfAny([‘,‘, ‘ ‘, ‘{‘, ‘"‘]) >= 0 then sRecord := ‘\"‘ + sRecord + ‘\"‘; Result := Result + ‘,‘ + sRecord; end; end; end; Result := ‘{"(‘ + Result.Substring(1) + ‘)"}‘; end; //测试 procedure TForm1.Button1Click(Sender: TObject); var s, s1, s2: string; begin UniQuery1.SQL.Text := ‘select * from t1‘; UniQuery1.Open; UniQuery1.First; s := DataSeRecordToArrayString(UniQuery1); UniQuery1.Next; s1 := DataSeRecordToArrayString(UniQuery1); UniQuery1.Next; s2 := DataSeRecordToArrayString(UniQuery1); with UniStoredProc1 do begin Close; ParamByName(‘p1‘).AsString := Format(‘{%s,%s,%s}‘, [s, s1, s2]); try ExecProc; except on E: Exception do begin ShowMessage(E.Message); Exit; end; end; ShowMessage(Fields[0].AsString); end; end;
变相解决Unidac无法向Postgresql传游标RefCursor的问题
标签: