DataSnap——利用TParams进行多表事务更新
DataSnap——利用TParams进行多表事务更新
服务端:
function TSVRDM.multUpdatesByPar(UpdateParam: TParams; out ErrMsg: string): OleVariant;
const
aSQL = 'Select * from %s where 1<>1';
var
i: Integer;
lQuery: TADOQuery;
lProvider: TDataSetProvider;
conn: TADOConnection;
ErrorCount, MaxErrors: Integer;
begin
Writeln(fguid + ':Mult-Table Update start ...');
conn := ConnPool.Lock(dbConnStr);
lQuery := TADOQuery.Create(NIL);
lProvider := TDataSetProvider.Create(nil);
Writeln(fguid + ': Start Transaction... ' );
conn.BeginTrans;
try
try
lQuery.Connection := conn;
lProvider.DataSet := lQuery;
for I := 0 to UpdateParam.Count-1 do begin
Writeln(fguid + ': Update Table ' + UpdateParam[i].Name);
lQuery.Close;
lQuery.SQL.Clear;
lQuery.SQL.Text := Format(aSQL, [UpdateParam[i].Name]);
result := lProvider.ApplyUpdates(UpdateParam[i].AsBytes, 0, ErrorCount);
ErrMsg := FErrMsg;
if ErrorCount > 0 then
raise Exception.Create(ErrMsg + '; TableName = '+UpdateParam[i].Name);
end;
conn.CommitTrans;
Writeln(fguid + ': Transaction commited... Update finished!' );
except
on E: Exception do
begin
conn.RollbackTrans;
Writeln(fguid + ':Transaction rollbacked! Update ERROR :' + E.Message);
end;
end;
finally
lProvider.Free;
lQuery.Free;
ConnPool.Unlock(conn);
FErrMsg := '';
end;
end;
客户端:
procedure TMyClient.btn1Click(Sender: TObject);
var
aParams: TParams;
aPar: TParam;
client: TDMClient;
ErrMsg: string;
begin
// TClientDataSet的Data和Delta可用TParam.AsBytes直接传递
aParams := TParams.Create(nil);
if ClientDataSet1.ChangeCount > 0 then
begin
aPar := aParams.CreateParam(ftVarBytes, '数据表1', ptInput);
aPar.AsBytes := ClientDataSet1.Delta;
end;
if ClientDataSet2.ChangeCount > 0 then
begin
aPar := aParams.CreateParam(ftVarBytes, '数据表2', ptInput);
aPar.AsBytes := ClientDataSet2.Delta;
end;
if aParams.Count = 0 then
exit;
client := TDMClient.Create(self.SQLConn.DBXConnection);
try
try
client.multUpdatesByPar(aParams, ErrMsg);
if ErrMsg <> '' then
raise Exception.Create(ErrMsg)
else
begin
ClientDataSet1.MergeChangeLog;
ClientDataSet2.MergeChangeLog;
end;
except
ON E: Exception do
begin
showmessage(E.Message);
end;
end;
finally
client.Free;
end;
end;
DataSnap——利用TParams进行多表事务更新的更多相关文章
- SQL Server 利用触发器对多表视图进行更新
其步骤就是:利用update操作触发器产生的2个虚拟表[inserted]用来存储修改的数据信息和[deleted]表,然后将对应的数据更新到对应数据表中的字段信息中: 1.首先创建3个表: a.信息 ...
- 利用Flume将MySQL表数据准实时抽取到HDFS
转自:http://blog.csdn.net/wzy0623/article/details/73650053 一.为什么要用到Flume 在以前搭建HAWQ数据仓库实验环境时,我使用Sqoop抽取 ...
- Oracle\MS SQL Server Update多表关联更新
原文:Oracle\MS SQL Server Update多表关联更新 一条Update更新语句是不能更新多张表的,除非使用触发器隐含更新.而表的更新操作中,在很多情况下需要在表达式中引用要更新的表 ...
- SDNLAB技术分享(四):利用ODL下发流表创建VxLAN网络
邓晓涛,当前就职于江苏省未来网络创新研究院,是CDN团队的一名研发人员,主要从事SDN相关的研发相关工作.曾就职于三星电子于先行解决方案研发组任高级工程师.思科系统于云协作应用技术部(CCATG)任工 ...
- Oracle 两个表之间更新的实现
Oracle 两个表之间更新的实现 来源:互联网 作者:佚名 时间:2014-04-23 21:39 Oracle中,如果跨两个表进行更新,Sql语句写成这样,Oracle 不会通过.查了资料,S ...
- (喷血分享)利用.NET生成数据库表的创建脚本,类似SqlServer编写表的CREATE语句
(喷血分享)利用.NET生成数据库表的创建脚本,类似SqlServer编写表的CREATE语句 在我们RDIFramework.NET代码生成器中,有这样一个应用,就是通过数据库表自动生成表的CREA ...
- sqlserver多表连接更新
一.MS SQL Server 多表关联更新 sql server提供了update的from 子句,可以将要更新的表与其它的数据源连接起来.虽然只能对一个表进行更新,但是通过将要更新的表与其它的数据 ...
- 利用sql批量删除表,存储过程
利用sql批量删除表,存储过程. 最近用godaddy的空间,由于系统里面的表多,一个个的删除很麻烦,就网上搜集了一下解决方法. 给大家分享一下: 1.批量删除存储过程 declare @procNa ...
- Postgresql两表联结更新
Postgresql两表联合更新近日使用Postgresql感到有点不好用,一个联合更新非要这样写语法才对:update d_routetripset name=b.name , descrip ...
随机推荐
- Redis 配置登录密码
1. 通过配置文件进行配置 打开 redis.conf,找到 #requirepass foobared 去掉行前的注释,并修改密码为所需的密码,保存文件 重启redis sudo service r ...
- jsp中/el表达式中将后台传来的时间戳格式化为年月日时分秒
sp中/el表达式中将后台传来的时间戳格式化为年月日时分秒1.引入相关标签库 <%@taglib prefix="c" uri="http://java.sun.c ...
- STL之string使用简介
声明一个C++字符串 string类的构造函数和析构函数如下: string s; //生成一个空字符串s string s(str) //拷贝构造函数 生成str的复制品 string s(str, ...
- Struts2请求流程
1. 一个请求在Struts2框架中的处理步骤: a) 客户端初始化一个指向Servlet容器的请求: b) 根据Web.xml配置,请求首先经过ActionContextCleanUp过滤器,其为可 ...
- PAT A+B格式
A + B格式(20) 时间限制 400毫秒 内存限制 65536 kB 代码长度限制 16000 B. 判断程序 标准 作者 陈,岳 计算a + b并以标准格式输出总和 - 即数字必须用逗号分隔成三 ...
- 目前问题:plupload上传带参数到后台
目前问题:plupload上传带参数到后台,迟迟没有解决!!! 昨晚到23点多终于完成了! 直接上代码! var uploader = new plupload.Uploader({ //实例化一个p ...
- jQuery操作DOM基础 - 元素属性的查看与设置
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- git refs 详解
https://blog.csdn.net/taiyangdao/article/details/52766424 http://www.chenchunyong.com/2017/01/06/git ...
- webpack-dev-server 支持其他设备访问配置
webpack-dev-server 打开的服务默认是只能localhost访问的,当有时候需要让别人访问的时候可以配置 --host 192.168.84 这样在同一个局域网下面就可以通过该ip来访 ...
- node系列
http://www.cnblogs.com/zhongweiv/p/nodejs.html