Delphi ADO数据操作封装类
- {
- 将数据集操作方面的东西全部封装成一个单独的类
- TcustomAdoDataSet是TadoQuery、TadoTable、TadoDataSet、TadoCommand的公共祖先类
- 应尽量使用TadoDataSet和TadoCommand类
- }
- unit untOpeDataSet;
- interface
- uses
- SysUtils,
- db, adodb, commonFunction, msg;
- type
- TopeDataSet = class
- public
- {修改已发生,但还没有得到应用的记录,在关闭窗口前应给予提示}
- function adoUpdatesPending(adoDataSet: TCustomAdoDataSet): boolean;
- {增加}
- procedure Append(adq: TadoQuery);
- {保存}
- procedure Save(adq: TadoQuery);
- {删除}
- procedure delete(adq: TadoQuery);
- {刷新数据集}
- procedure flash(adq: TadoQuery);
- {事务提交}
- procedure adqCommit(adq: TadoQuery);
- {查询数据集}
- procedure adqQuery(adq: TadoQuery; s: string);
- {带参查询数据集}
- procedure adqQueryPara(adq: TadoQuery; s: string; s1: variant);
- procedure adqQueryPara2(adq: TadoQuery; s: string; s1: variant; s2: variant);
- procedure adqQueryPara3(adq: TadoQuery; s: string; s1: variant; s2: variant; s3: variant);
- procedure adqQueryPara4(adq: TadoQuery; s: string; s1: variant; s2: variant; s3: variant; s4: variant);
- {更新数据集}
- procedure adqExec(adq: TadoQuery; s: string);
- {带参更新数据集}
- procedure adqExecPara(adq: TadoQuery; s: string; s1: variant);
- procedure adqExecPara2(adq: TadoQuery; s: string; s1: variant; s2: variant);
- procedure adqExecPara3(adq: TadoQuery; s: string; s1: variant; s2: variant; s3: variant);
- procedure adqExecPara5(adq: TadoQuery; s: string; s1: variant; s2: variant; s3: variant; s4: variant; s5: variant);
- procedure adqExecPara6(adq: TadoQuery; s: string; s1: variant; s2: variant; s3: variant; s4: variant; s5: variant; s6: variant);
- end;
- implementation
- { TopeDataSet }
- function TopeDataSet.adoUpdatesPending(
- adoDataSet: TCustomAdoDataSet): boolean;
- var
- clone: TadoDataSet;
- begin
- clone := TadoDataSet.create(nil);
- try
- clone.clone(adoDataSet); //复制
- clone.filterGroup := fgPendingRecords; //已得到修改但还没有得到应用的所有记录
- clone.filtered := true;
- result := not(clone.bof and clone.eof);
- clone.close;
- finally
- clone.free;
- end;
- end;
- procedure TopeDataSet.adqCommit(adq: TadoQuery);
- begin
- try
- adq.Connection.CommitTrans;
- info(SopeSuccess, Scorp);
- except
- adq.Connection.RollbackTrans;
- info(SopeFail, Scorp, 16);
- end;
- end;
- procedure TopeDataSet.adqExec(adq: TadoQuery; s: string);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.ExecSQL;
- end;
- procedure TopeDataSet.adqExecPara(adq: TadoQuery; s: string;
- s1: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.ExecSQL;
- end;
- procedure TopeDataSet.adqExecPara2(adq: TadoQuery; s: string; s1,
- s2: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.Parameters[1].Value := s2;
- adq.ExecSQL;
- end;
- procedure TopeDataSet.adqExecPara3(adq: TadoQuery; s: string; s1,
- s2, s3: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.Parameters[1].Value := s2;
- adq.Parameters[2].Value := s3;
- adq.ExecSQL;
- end;
- procedure TopeDataSet.adqExecPara5(adq: TadoQuery; s: string; s1,
- s2, s3, s4, s5: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.Parameters[1].Value := s2;
- adq.Parameters[2].Value := s3;
- adq.Parameters[3].Value := s4;
- adq.Parameters[4].Value := s5;
- adq.ExecSQL;
- end;
- procedure TopeDataSet.adqExecPara6(adq: TadoQuery; s: string; s1,
- s2, s3, s4, s5, s6: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.Parameters[1].Value := s2;
- adq.Parameters[2].Value := s3;
- adq.Parameters[3].Value := s4;
- adq.Parameters[4].Value := s5;
- adq.Parameters[5].Value := s6;
- adq.ExecSQL;
- end;
- procedure TopeDataSet.adqQuery(adq: TadoQuery; s: string);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Open;
- end;
- procedure TopeDataSet.adqQueryPara(adq: TadoQuery; s: string;
- s1: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.open;
- end;
- procedure TopeDataSet.adqQueryPara2(adq: TadoQuery;
- s: string; s1, s2: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.Parameters[1].Value := s2;
- adq.open;
- end;
- procedure TopeDataSet.adqQueryPara3(adq: TadoQuery;
- s: string; s1, s2, s3: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.Parameters[1].Value := s2;
- adq.Parameters[2].Value := s3;
- adq.Open;
- end;
- procedure TopeDataSet.adqQueryPara4(adq: TadoQuery;
- s: string; s1, s2, s3, s4: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.Parameters[1].Value := s2;
- adq.Parameters[2].Value := s3;
- adq.Parameters[3].Value := s4;
- adq.Open;
- end;
- procedure TopeDataSet.Append(adq: TadoQuery);
- begin
- adq.Append;
- end;
- procedure TopeDataSet.delete(adq: TadoQuery);
- var
- i: integer;
- begin
- if adq.IsEmpty then
- abort;
- i := adq.RecNo;
- if queryInfo(SifDel, Scorp) then
- begin
- try
- adq.RecNo := i;
- adq.Delete;
- adq.UpdateBatch(); //批更新
- except
- adq.CancelBatch();
- info(SdelError, Scorp, 16);
- end;
- end;
- end;
- procedure TopeDataSet.flash(adq: TadoQuery);
- begin
- adq.Close;
- adq.Open;
- end;
- procedure TopeDataSet.Save(adq: TadoQuery);
- begin
- try
- adq.UpdateBatch();
- info(Ssave_success, Scorp);
- except
- adq.CancelBatch();
- info(Ssave_fail, Scorp, 16);
- end;
- end;
- end.
- procedure adqExec(adq: TadoQuery; s: string);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.ExecSQL;
- end;
- procedure adqExecPara(adq: TadoQuery; s: string;
- s1: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.ExecSQL;
- end;
- procedure adqQuery(adq: TadoQuery; s: string);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Open;
- end;
- procedure adqQueryPara(adq: TadoQuery; s: string; s1: variant);
- begin
- adq.Close;
- adq.SQL.Clear;
- adq.SQL.Text := s;
- adq.Parameters[0].Value := s1;
- adq.open;
- end;
- procedure Append(adq: TadoQuery);
- begin
- adq.Append;
- end;
- procedure delete(adq: TadoQuery);
- var
- i: integer;
- begin
- if adq.IsEmpty then
- abort;
- i := adq.RecNo;
- if queryInfo(SifDel, Scorp) then
- begin
- try
- adq.RecNo := i;
- adq.Delete;
- adq.UpdateBatch();
- except
- adq.CancelBatch();
- showmessage('Fail');
- end;
- end;
- end;
- procedure flash(adq: TadoQuery);
- begin
- adq.Close;
- adq.Open;
- end;
- procedure Save(adq: TadoQuery);
- begin
- try
- adq.UpdateBatch();
- showmessage('Success');
- except
- adq.CancelBatch();
- showmessage('Fail');
- end;
- end;
- end.
Delphi ADO数据操作封装类的更多相关文章
- Android 常用数据操作封装类案例
1.DbHelper类 继承自SQLiteOpenHelper类,实现对数据库的基本操作 package com.example.utils; import android.content.Conte ...
- 初始ADO.NET数据操作
以下介绍直接来源与百度百科,介绍十分全面和详细,作为小菜的我们没有理由不看完这些枯燥的介绍原有: ADO.NET的名称起源于ADO(ActiveX Data Objects),是一个COM组件库,用于 ...
- ADO.NET访问Access(文本数据库)数据操作(CRUD)
1,ADO.NET访问Access(文本数据库)数据操作(CRUD) 2,DatabaseDesign 文本数据库Northwind.mdb 3,/App_Code 3.1,/App_Code/DBC ...
- ADO.NET 对数据操作 以及如何通过C# 事务批量导入数据
ADO.NET 对数据操作 以及如何通过C# 事务批量导入数据 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 ...
- C# 数据操作系列 - 2. ADO.NET操作
0.前言 在上一篇中初略的介绍了一下SQL的基本写法,这一篇开始我们正式步入C#操作数据库的范围.通过这一系列的内容,我想大家能对于数据库交互有了一定的认识和基础.闲话不多说,先给大家介绍一个C#操作 ...
- 编写Java程序,在维护英雄数据的业务过程中复用数据库操作封装类
返回本章节 返回作业目录 需求说明: 继续完善英雄信息系统,将HeroAccess类中数据库连接相关代码独立出来,并将其封闭成数据库操作工具类DbConnection,便于管理和代码复用. 在Hero ...
- Delphi简单的数据操作类
unit MyClass; uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, VCL ...
- Asp.Net Core 2.0 项目实战(4)ADO.NET操作数据库封装、 EF Core操作及实例
Asp.Net Core 2.0 项目实战(1) NCMVC开源下载了 Asp.Net Core 2.0 项目实战(2)NCMVC一个基于Net Core2.0搭建的角色权限管理开发框架 Asp.Ne ...
- 我的DbHelper数据操作类
其实,微软的企业库中有一个非常不错的数据操作类了.但是,不少公司(起码我遇到的几个...),对一些"封装"了些什么的东西不太敢用,虽然我推荐过微软的企业库框架了...但是还是要&q ...
随机推荐
- cakephp , the subquery (2)
Cakephp 框架帮我们做了很多的工作,的确省了我们很多工作,提高了效率. 但是,碰到一些比较复杂的查询时,还是有些问题,官方的cookbook api 有说明一些详细的用法,但感觉还是不太够,有些 ...
- Linux基本命令之用户系统相关命令
1.格式说明 [simon@localhost simon]$ [simon@localhost ~]$ 这两种方式表示相同.simon是指定用户,localhost是计算机名字,如果不设置默认为lo ...
- git log 查看 当前分支的 提交历史
git log 查看 当前分支的 提交历史 在提交了若干更新之后,想回顾下提交历史,可以使用 git log 命令查看 默认不用任何参数的话,git log 会按提交时间列出所有的更新,最近的更新排 ...
- JS基础知识(五)
内置对象 定义:JS语言自己定义的一些对象,供开发者使用. 常用内置对象: 1.Arguments对象 arguments.length 返回实参的个数 他只在正运行的函数内部使用.argument ...
- (中等) CF 311B Cats Transport,斜率优化DP。
Zxr960115 is owner of a large farm. He feeds m cute cats and employs p feeders. There's a straight r ...
- POJ 2653 Pick-up sticks
计算几何,判断线段相交 注意题目中的一句话:You may assume that there are no more than 1000 top sticks. 我认为是没有描述清楚的,如果不是每次 ...
- js获取光标位置
js获取光标位置 var TT = { /* * 获取光标位置 * @Method getCursorPosition * @param t element * @return number */ ...
- shell字符串操作之cut---实现字符串截取
shell中(字符串截取) cut是以每一行为一个处理对象的,这种机制和sed是一样的.(关于sed的入门文章将在近期发布) 2 cut一般以什么为依据呢? 也就是说,我怎么告诉cut我想定位到的剪切 ...
- Spring自学教程-IOC、DI、AOP(二)
一.spring的IOC-就是怎样使用spring来创建对象 二.springDI(依赖注入)-就是怎样给属性赋值 通过set方式赋值 以下我们只需要记住两点的赋值,基本类型和引用类型的赋值 基本类型 ...
- IOS FMDB模糊查询
http://blog.sina.com.cn/s/blog_9630f1310101fx1d.html /查询记录 -(NSArray*)selectitemDream_desc:(JiemengS ...
