unit UMemtableToSql;

interface

uses SysUtils, Classes, DB, kbmMemTable, Variants, Dialogs, SuperObject;

function GenerateDataToInsertSQL(memtbale: TkbmMemTable; UpdateTableName: AnsiString; NoUpdateFields: TStrings): TStringList; //插入数据
//不需要更新的字段描述 [NoUpdateFields]
function GenerateDataToModifySQL(memtbale: TkbmMemTable; UpdateTableName: AnsiString; NoUpdateFields: TStrings; sWhereFiled: string): TStringList; //编辑数据

function GenerateDataToDeleteSQL(memtbale: TkbmMemTable; UpdateTableName: AnsiString; KeyFields: TStrings; sWhereFiled: string): TStringList; //删除数据

function ConvertStringsToJSON(ss: TStrings): WideString;

function ApplyInsertMemtable(memtbale: TkbmMemTable; UpdateTableName: AnsiString):AnsiString;

implementation

uses UBizServerModule;
function ExistString(subString: string;
sList: TStrings): boolean;
var
i: integer;
begin
result := false;
for i := 0 to sList.Count - 1 do
begin
if UpperCase(subString) = UpperCase(sList[i]) then
result := true;
end;

end;

procedure CustomSysdate(var ss: string;
const sField, DateTimeType: string);
begin
if (trim(DateTimeType) = '') or (UpperCase(DateTimeType) = 'ORACLE') then
ss := ss + sField + ' sysdate , ';

if UpperCase(DateTimeType) = 'MYSQL' then
ss := ss + sField + ' sysdate() , ';

if UpperCase(DateTimeType) = 'SQLSERVER' then
ss := ss + sField + ' GetDate() , ';

if UpperCase(DateTimeType) = 'SQLITE' then
ss := ss + sField + ' datetime(''now'') , ';

end;

procedure CustomTo_date(var sSet: string;
const sField, DateTimeType, vNew: string);
begin
if (trim(DateTimeType) = '') or (UpperCase(DateTimeType) = 'ORACLE') then
sSet := sSet + sField + ' to_date(''' + (vNew) + ''' , ''yyyy-MM-dd HH24:mi:ss''), ';
// sSet := sSet + sField + uHHConst.HHUniDateStr(vNew) ;

if UpperCase(DateTimeType) = 'MYSQL' then
sSet := sSet + sField + ' ''' + (vNew) + ''' , ';

if UpperCase(DateTimeType) = 'SQLITE' then
sSet := sSet + sField + ' ''' + (vNew) + ''' , ';

if UpperCase(DateTimeType) = 'SQLSERVER' then
sSet := sSet + sField + ' ''' + (vNew) + ''' , ';

end;

function CustomBoolean(vNew: string;
const sField, DateTimeType: string): string;
begin
Result := vNew;
if (trim(DateTimeType) = '') or (UpperCase(DateTimeType) = 'ORACLE') or (
UpperCase(DateTimeType) = 'MYSQL') then
begin
if UpperCase(vNew) = 'TRUE' then Result := '''1''';
if UpperCase(vNew) = 'FALSE' then Result := '''0''';
end;

{ ' ''' + VarToStr(vNew) + '''
if DateTimeType = 'MYSQL' then
begin
if vNew = 'true' then Result := '''1''' ;
if vNew = 'false' then Result := '''0''';
end;

if DateTimeType = 'SQLSERVER' then
ss := ss + sField + ' GetDate() , ';
}

end;

function GenerateDataToInsertSQL(memtbale: TkbmMemTable; UpdateTableName: AnsiString; NoUpdateFields: TStrings): TStringList;
var
i: integer;
s, sWhere, sFieldNames, sValues: string;
FDataToInsertSQL: TStringList;
vNew: variant;
DateTimeType: string;
begin
DateTimeType := 'MYSQL';
FDataToInsertSQL := TStringList.Create;
FDataToInsertSQL.Clear;
Result := nil;

if UpdateTableName = '' then
begin
ShowMessage('UpdateTableName 不能为空!');
exit;
end;
with memtbale do
begin
First;

while not EOF do
begin
s := 'insert into ' + UpdateTableName;
sWhere := ' ';
sFieldNames := ' (';
sValues := ' VALUES (';

for i := 0 to FieldCount - 1 do
begin
if NoUpdateFields.IndexOf(Fields[i].FieldName) < 0 then
if (not (Fields[i].DataType in kbmBinaryTypes)) or (Fields[i].DataType = ftMemo) then
begin
if UpperCase(Fields[i].FieldName) = 'ID_AUTO' then continue;
if UpperCase(Fields[i].FieldName) = 'ID' then continue;

vNew := Fields[i].Value;
if not (VarIsNull(vNew)) then
begin
sFieldNames := sFieldNames + Fields[i].FieldName + ', ';
if (Fields[i].DataType = ftBoolean) then
begin
//if vNew = 'true' then vNew := '1';
// if vNew = 'false' then vNew := '0';
vNew := CustomBoolean(vNew, '', DateTimeType);
sValues := sValues + VarToStr(vNew) + ', '
end
else if (Fields[i].DataType = ftDateTime) then
begin
if (Fields[i].FieldName = 'OPT_UPDATE_TIME') or
(Fields[i].FieldName = 'STOCK_OUT_TIME') or
(Fields[i].FieldName = 'STOCK_IN_TIME')
then
begin
{if DateTimeType = 'MYSQL' then
sValues := sValues + ' sysdate() , ';

if (trim(DateTimeType) = '') or (DateTimeType = 'ORACLE') then
sValues := sValues + ' sysdate , '; }
CustomSysdate(sValues, '', DateTimeType);
end
else
if (Fields[i].FieldName = 'update_time') or (Fields[i].FieldName = 'sample_time') then
begin
{if (trim(DateTimeType) = '') or (DateTimeType = 'ORACLE') then
sValues := sValues + ' sysdate , ';

if DateTimeType = 'MYSQL' then
sValues := sValues + ' sysdate() , ';

if DateTimeType = 'SQLSERVER' then
sValues := sValues + ' GetDate() , '; }
CustomSysdate(sValues, '', DateTimeType);
end
else
begin
{if (trim(DateTimeType) = '') or (DateTimeType = 'ORACLE') then
sValues := sValues + ' to_date(''' + VarToStr(vNew) + ''' , ''yyyy-MM-dd HH24:mi:ss''), ';

if DateTimeType = 'MYSQL' then
sValues := sValues + '''' + VarToStr(vNew) + ''' , ';

if DateTimeType = 'SQLSERVER' then
sValues := sValues + '''' + VarToStr(vNew) + ''' , ';
}
CustomTo_date(sValues, '', DateTimeType, VarToStr(vNew));
end;
end
else if (Fields[i].DataType = ftInteger) or (Fields[i].DataType = ftCurrency) or (Fields[i].DataType = ftFloat) then
begin
sValues := sValues + VarToStr(vNew) + ', ';
end
else
sValues := sValues + ' ''' + VarToStr(vNew) + ''', '
end;

{//一般不会用到这个,因为SID一般不能为空
if (VarIsNull(vNew)) then
begin
if Fields[i].FieldName = 'SID' then
begin
//处理Sequence
sFieldNames := sFieldNames + Fields[i].FieldName + ', ';
sValues := sValues + (DataSet as TkbmMemTableHH).UpdateTableName + '_SEQ.nextval, ';
end;
end; }
end;

end;

if sFieldNames = '' then exit;
if sValues = '' then exit;

if sWhere <> '' then sWhere := ' where ' + sWhere;
if sFieldNames <> '' then
begin
sFieldNames := Copy(sFieldNames, 1, Length(sFieldNames) - 2) + ') ';
end;
if sValues <> '' then
begin
sValues := Copy(sValues, 1, Length(sValues) - 2) + ') ';
end;

FDataToInsertSQL.Add(s + sFieldNames + sValues);
Next;
end;
end;

Result := FDataToInsertSQL;

end;

function GenerateDataToModifySQL(memtbale: TkbmMemTable; UpdateTableName: AnsiString; NoUpdateFields: TStrings; sWhereFiled: string): TStringList;
var
i: integer;
s, sWhere, sSet: string;
FDataToModifySQL: TStringList;
vNew: variant;
DateTimeType: string;
begin
Result := nil;
DateTimeType := 'MYSQL';
if UpdateTableName = '' then
begin
ShowMessage('UpdateTableName 不能为空!');
exit;
end;

FDataToModifySQL := TStringList.Create;
FDataToModifySQL.Clear;
with memtbale do
begin
First;
while not EOF do
begin
s := 'Update ' + UpdateTableName;
sWhere := ' ';
sSet := ' ';

for i := 0 to FieldCount - 1 do
begin
if NoUpdateFields.IndexOf(Fields[i].FieldName) < 0 then
if (not (Fields[i].DataType in kbmBinaryTypes)) or (Fields[i].DataType = ftMemo) then
begin
if UpperCase(Fields[i].FieldName) = 'ROWID' then continue;
if UpperCase(Fields[i].FieldName) = 'ID_AUTO' then continue;
if UpperCase(Fields[i].FieldName) = 'ID' then continue;

vNew := Fields[i].Value;
//vOld := OrigValues[i];

if (not (VarIsNull(vNew))) then
//if vNew <> vOld then
begin
//if not ExistString(Fields[i].FieldName, (DataSet as TkbmMemTableHH).KeyFields) then
begin
if (Fields[i].DataType = ftBoolean) then
begin
// if vNew = 'true' then vNew := '1';
//if vNew = 'false' then vNew := '0';
vNew := CustomBoolean(vNew, '', DateTimeType);
sSet := sSet + Fields[i].FieldName + ' = ' + VarToStr(vNew) + ', '
end
else if (Fields[i].DataType = ftDateTime) then
begin
if Fields[i].FieldName = 'OPT_UPDATE_TIME' then
//sSet := sSet + Fields[i].FieldName + ' = sysdate , '
CustomSysdate(sSet, Fields[i].FieldName + ' = ',
DateTimeType)
else
if (Fields[i].FieldName = 'update_time') or (Fields[i].FieldName = 'sample_time') then
begin
if DateTimeType <> 'SQLSERVER' then
sSet := sSet + Fields[i].FieldName + ' = GetDate() , ';

CustomSysdate(sSet, Fields[i].FieldName + ' = ', DateTimeType);
end
else
begin
CustomTo_date(sSet, Fields[i].FieldName + ' = ', DateTimeType, VarToStr(vNew));
end;

end
else if (Fields[i].DataType = ftInteger) or (Fields[i].DataType = ftCurrency) or (Fields[i].DataType = ftFloat) then
begin
sSet := sSet + Fields[i].FieldName + ' = ' + VarToStr(vNew) + ', '
end
else
sSet := sSet + Fields[i].FieldName + ' = ''' + VarToStr(vNew) + ''', '
end;
end;

end;

{if ExistString(Fields[i].FieldName, KeyFields) then
begin
if trim(sWhere) <> '' then
sWhere := sWhere + ' and ' + Fields[i].FieldName + ' = ' + VarToStr(vOld)
else
sWhere := sWhere + Fields[i].FieldName + ' = ' + VarToStr(vOld);

end; }

sWhere := ' ' + sWhereFiled + ' = ' + FieldByName('' + sWhereFiled + '').AsString;
end;

if trim(sSet) = '' then exit;
if trim(sWhere) = '' then
begin
ShowMessage('sWhere 为空!');
exit;
end;

if sWhere <> '' then sWhere := ' where ' + sWhere;
if sSet <> '' then
begin
sSet := ' Set ' + Copy(sSet, 1, Length(sSet) - 2); ;
end;

FDataToModifySQL.Add(s + sSet + sWhere);
Next;

end;
end;
//(DataSet as TkbmMemTableHH).ModifySQL := s + sSet + sWhere;
Result := FDataToModifySQL;

end;

function GenerateDataToDeleteSQL(memtbale: TkbmMemTable; UpdateTableName: AnsiString; KeyFields: TStrings; sWhereFiled: string): TStringList;
var
i: integer;
s, sWhere: string;
v: variant;
FDataToDeleteSQL: TStringList;
begin
FDataToDeleteSQL := TStringList.Create;
FDataToDeleteSQL.Clear;
Result := nil;

if UpdateTableName = '' then
begin
ShowMessage('UpdateTableName 不能为空!');
exit;
end;
with memtbale do
begin
First;

while not EOF do
begin
s := 'Delete from ' + UpdateTableName;
sWhere := '';

for i := 0 to FieldCount - 1 do
begin
v := Fields[i].Value;

if UpperCase(Fields[i].FieldName) = 'ROWID' then continue;
if UpperCase(Fields[i].FieldName) = 'ID_AUTO' then continue;
if UpperCase(Fields[i].FieldName) = 'ID' then continue;

if ExistString(Fields[i].FieldName, KeyFields) then
sWhere := sWhere + Fields[i].FieldName + ' = ' + VarToStr(v) + ' and ';
end;

if sWhere <> '' then sWhere := ' where ' + Copy(sWhere, 1, Length(sWhere) - 4);
// (DataSet as TkbmMemTableHH).DeleteSQL := s + sWhere;

if sWhere = '' then sWhere := ' where ' + sWhereFiled + ' = ' + FieldByName(sWhereFiled).AsString;
FDataToDeleteSQL.Add(s + sWhere);
Next;
end;
end;

Result := FDataToDeleteSQL;
end;

// 转换成json
function ConvertStringsToJSON(ss: TStrings): WideString;
var
jo: ISuperObject;
i: Integer;
begin
jo := TSuperObject.Create;

for i := 0 to ss.Count - 1 do
jo.S['YHYSQL' + IntToStr(i)] := ss[i];

Result := jo.AsString;

end;

//提交数据到服务器,进行操作
function ApplyInsertMemtable(memtbale: TkbmMemTable; UpdateTableName: AnsiString):AnsiString;
var sList:TStringList;
vjson:string;
begin
sList:=TStringList.Create;
sList:=GenerateDataToInsertSQL(memtbale,UpdateTableName,sList);
vjson:=ConvertStringsToJSON(sList);
Result:=fBizServerModule.getBaseService.ExecJsonSqls(vjson);
sList:=nil;
end;

end.

delphi中Tkbmmemtable数据转成SQL脚本的更多相关文章

  1. [软件共享]将数据库中的数据导出为SQL脚本

    可以直接将数据库中的数据导出为脚本,并可以自己设置过滤条件.使用方法很简单,不在多说了.下面是软件截图.123 下载:http://files.cnblogs.com/pw/mssql2.rar

  2. SQL Server将数据导出到SQL脚本文件

    http://www.studyofnet.com/news/list-8883.2-1-4.html 一.SQL Server 2008将数据导出到SQL脚本文件 1.打开SQL Server200 ...

  3. Excel数据转化为sql脚本

    在实际项目开发中,有时会遇到客户让我们把大量Excel数据导入数据库的情况.这时我们就可以通过将Excel数据转化为sql脚本来批量导入数据库. 1 在数据前插入一列单元格,用来拼写sql语句. 具体 ...

  4. [转]Excel数据转化为sql脚本

    在实际项目开发中,有时会遇到客户让我们把大量Excel数据导入数据库的情况.这时我们就可以通过将Excel数据转化为sql脚本来批量导入数据库. 1 在数据前插入一列单元格,用来拼写sql语句. 具体 ...

  5. 使用excel中的数据快速生成sql语句

    在小公司的话,总是会有要开发去导入历史数据(数据从旧系统迁移到新系统上)的时候.这个时候,现场实施或客户会给你一份EXCEL文档,里面包含了一些别的系统上的历史数据,然后就让你导入到现在的系统上面去. ...

  6. 【原创】SQLServer将数据导出为SQL脚本的方法

    最近很多同学问到一个问题,如何将MSSQLServer的数据库以及里面的数据导出为SQL脚本,主要问的是MSSQLServer2000和2005,因为2008的管理器已经有了这个功能,2000和200 ...

  7. OC中如何把字典中的数据拼接成url字符串

    在使用objective-c语言开发iOS应用中,会向服务器通过URL请求一些数据,因此对URL的拼接肯定少不了.而在iOS中,我们一般是通过将字典中的数据拼接成我们要请求的URL字符串,那这个是怎么 ...

  8. SQLserver将查询的字段中的数据 拼接成字符串用逗号隔开

    ,,'') 将查询的字段中的数据 拼接成字符串用逗号隔开

  9. 在EA中将画出的ER图转换成SQL脚本

    在进行数据库设计的时候,想着正好安装着EA软件呢,看能不能用EA画ER模型.结果发现不仅能画.并且还能进行整套数据库设计(生成SQL脚本). 以下以机房收费系统用户--学生为例.学生能够查看剩余金额. ...

随机推荐

  1. 论文笔记-IGCV3:Interleaved Low-Rank Group Convolutions for Efficient Deep Neural Networks

    论文笔记-IGCV3:Interleaved Low-Rank Group Convolutions for Efficient Deep Neural Networks 2018年07月11日 14 ...

  2. gridview单元格编辑添加数据

    行号 private void gridView1_CustomDrawRowIndicator(object sender, DevExpress.XtraGrid.Views.Grid.RowIn ...

  3. 你不知道的css各类布局(二)之流体布局、液体布局、栅格布局

    流体布局 什么是流 在谈论流体布局之前我们需要知道一件事情就是何为“流”,所谓“流”就是“文档流”,是css中的一种基本定位和布局 概念 流体布局(Liquid/Fluid Layout)指的是利用元 ...

  4. JS基础_条件运算符

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  5. 使用HandyJSON导致的内存泄漏问题相关解决方法

    在移动开发中,与服务器打交道是不可避免的,从服务器拿到的接口数据最终都会被我们解析成模型,现在比较常见的数据传输格式是json格式,对json格式的解析可以使用原生的解析方式,也可以使用第三方的,我们 ...

  6. 5.Linux 软件安装管理

    1.RPM包安装 (RPM会有依赖性,即安装这个包之前,需要安装某个包) 查询已安装的rpm 列表   rpm  -qa | grep  xx 安装rpm包 rpm  -ivh  rpm  包名 -i ...

  7. JDBC及PreparedStatement防SQL注入

    概述 JDBC在我们学习J2EE的时候已经接触到了,但是仅是照搬步骤书写,其中的PreparedStatement防sql注入原理也是一知半解,然后就想回头查资料及敲测试代码探索一下.再有就是我们在项 ...

  8. 《python解释器源码剖析》第1章--python对象初探

    1.0 序 对象是python中最核心的一个概念,在python的世界中,一切都是对象,整数.字符串.甚至类型.整数类型.字符串类型,都是对象.换句话说,python中面向对象的理念观测的非常彻底,面 ...

  9. ScrollView 滚动视图

    ScrollView 种类: 1.HorizontalScrollView:水平滚动视图 2.ScrollView:垂直滚动视图(常用类) public class MainActivity exte ...

  10. 1.Netty 实战前言

    1.参考文档:Netty实战精髓篇 2.Netty介绍:     Netty是基于Java NIO的网络应用框架. Netty是一个NIO client-server(客户端服务器)框架,使用Nett ...