DELPHI 数据库连接类

做的时候目地是可以通过类的创建和释放进行数据库的短连接,在做服务端的时候每一个请求都通过类生成一个数据连接

unit UnDm;

interface

uses
SysUtils, Classes, Controls, Forms, Dialogs,
ComCtrls, ExtCtrls, Menus, StdCtrls,
ADODB,
DB,inifiles; type
TRecordResult = (RRError, RRZero, RROK);
TDataStatus = (DsSel, DsEdit, DsAdd);
type
TDataConnection = class
DataAdoConn: TADOConnection;
qryTemp1: TADOQuery;
qryTemp2: TADOQuery;
qryTemp3: TADOQuery;
qryTemp4: TADOQuery; private public
constructor Create; overload;
//连接数据库
function DbConn: Boolean; //启动事物
function AdoBeginTrans: Boolean;
//回滚事物
function AdoRollbackTrans: Boolean;
//提交事物
function AdoCommitTrans: Boolean;
//
Function GetOpenQuery(const sSql, sTitle: String; _AdoQry: TADOQuery; Is_View: Boolean = True): TRecordResult; overload;
function UpdateSql(const sSql, sTitle: String; IsView: Boolean= True): TRecordResult;
function GetAllUser: Integer;
end; implementation
uses Querypa; constructor TDataConnection.Create;
var
I:Integer;
begin
inherited;
DataAdoConn:=TADOConnection.Create(nil);
qryTemp1:=TADOQuery.Create(nil);
qryTemp2:=TADOQuery.Create(nil);
qryTemp3:=TADOQuery.Create(nil);
qryTemp4:=TADOQuery.Create(nil);
DataAdoConn.LoginPrompt:=False;
qryTemp1.Connection:=DataAdoConn;
qryTemp2.Connection:=DataAdoConn;
qryTemp3.Connection:=DataAdoConn;
qryTemp4.Connection:=DataAdoConn;
end; function TDataConnection.DbConn: Boolean;
const
//sDbConn = 'Provider=OraOLEDB.Oracle.1;Password=%s;Persist Security Info=True;User ID=%s;Data Source=%s';
sDbConn = 'Provider=OraOLEDB.Oracle.1;Password=%s;User ID=%s;Data Source=%s;Persist Security Info=True';
var
sUdlFile: String;
ServerIni:TiniFile;
SOURCE,USER,PASSWORD:string;
sSql:string;
begin
//获得数据库连接串
ServerIni := TIniFile.Create(ExtractFilePath(Application.ExeName) + 'ServerInfor.Ini');
SOURCE := ServerIni.ReadString('HIS', 'SOURCE', '');
USER := ServerIni.ReadString('HIS', 'USER', '');
PASSWORD := ServerIni.ReadString('HIS', 'PASSWORD', '');
sSql := Format(sDbConn, [PASSWORD, USER, SOURCE]);
Result := False;
if DataAdoConn.Connected then
DataAdoConn.Close;
//连接数据库
DataAdoConn.ConnectionString :=sSql; //'FILE NAME='+sUdlFile;
Try
DataAdoConn.Open;
if not DataAdoConn.Connected then
begin
Result :=false;
Exit;
end
else
begin
Result :=true;
end;
Except
Result := False;
Exit;
end;
end; function TDataConnection.AdoBeginTrans: Boolean;
Var
nResult: Integer;
begin
Result := False;
Try
nResult := DataAdoConn.BeginTrans;
if nResult > then
Result := True;
except
On E: Exception do
Begin
SaveError('启动事务', E.Message);
end;
end;
end;
function TDataConnection.AdoCommitTrans: Boolean;
Var
nResult: Integer;
begin
Result := False;
Try
DataAdoConn.CommitTrans;
Result := True;
except
On E: Exception do
Begin
SaveError('提交事务', E.Message);
end;
end; end; function TDataConnection.AdoRollbackTrans: Boolean;
Var
nResult: Integer;
begin
Result := False; Try
DataAdoConn.RollbackTrans;
Result:True;
except
On E: Exception do
Begin
SaveError('回滚事务', E.Message);
end;
end;
end; /// <summary>
/// 更新数据库涵数 插入或修改
/// sSql SQL语句
/// sTitle执行标题
/// IsView出错后是否弹出消息
/// </summary>
function TDataConnection.UpdateSql(const sSql, sTitle: String;
IsView: Boolean): TRecordResult;
Var
nResult: Integer;
AdoQry:TADOQuery;
begin
AdoQry:=TADOQuery.Create(nil);
AdoQry.Connection:= DataAdoConn;
Result := RRError;
With AdoQry do
Begin
Close;
SQL.Text := sSql;
Try
nResult := ExecSQL;
if nResult = then
Result := RRZero
else
Result := RROK;
Except
on E: Exception do
Begin
SaveError(sTitle, sSql+ ## +E.Message);
MsgShow(E.Message, );
Exit;
end;
end;
end;
if Result = RRZero then
Begin
SaveError(sTitle, sSql+ ## +'执行没有返回正确结果!');
if IsView then
MsgShow('执行没有返回正确结果!', );
Exit;
end;
end; /// <summary>
/// 查询数据库语句
/// sSql SQL语句
/// sTitle执行标题
/// _AdoQry Adoquery控件
/// IsView出错后是否弹出消息
/// </summary>
function TDataConnection.GetOpenQuery(const sSql, sTitle: String; _AdoQry: TADOQuery;
Is_View: Boolean): TRecordResult;
begin
Result := RRError;
With _AdoQry do
Begin
Close;
SQL.Text := sSql;
Try
Open;
if IsEmpty then
Result := RRZero;
if Not IsEmpty then
Result := RROK;
Except
on E: Exception do
Begin
SaveError(sTitle, sSql+ ## +E.Message);
MsgShow(E.Message, );
Exit;
end;
end;
end;
if (Result = RRZero) and Is_View then
Begin
SaveError(sTitle, sSql+ ## + sTitle);
MsgShow(sTitle, );
end;
end; function TDataConnection.GetAllUser: Integer;
begin
with qryTemp1 do
begin
Close;
SQL.Text := 'SELECT USERID, name From T_USERS';
Open;
end;
Result := qryTemp1.RecordCount;
end; end.
————————————————

声明

var
dm: TDataConnection;

创建

//首选连接服务器数据库
dm:=TDataConnection.Create;
if not dm.DbConn then
begin
MsgShow('服务器数据库连接失败,无法启动服务',);
dm.Free;
Exit;
end;

执行SQL语句

  strSQL:=' UPDATE A SET AA=''1''';
DM.UpdateSql(strSQL,'更新数据库',false);

查询数据库

  strSQL:=' SELECT * FROM A';
DM.GetOpenQuery(strSQL,'更新数据库',ADOQUERY1,false);

事务就添加TRY后在里面增加事务就可以

DELPHI 数据库操作类(工具类)的更多相关文章

  1. 自己封装的poi操作Excel工具类

    自己封装的poi操作Excel工具类 在上一篇文章<使用poi读写Excel>中分享了一下poi操作Excel的简单示例,这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完 ...

  2. Redis操作Set工具类封装,Java Redis Set命令封装

    Redis操作Set工具类封装,Java Redis Set命令封装 >>>>>>>>>>>>>>>>& ...

  3. Redis操作List工具类封装,Java Redis List命令封装

    Redis操作List工具类封装,Java Redis List命令封装 >>>>>>>>>>>>>>>> ...

  4. Redis操作Hash工具类封装,Redis工具类封装

    Redis操作Hash工具类封装,Redis工具类封装 >>>>>>>>>>>>>>>>>> ...

  5. Redis操作字符串工具类封装,Redis工具类封装

    Redis操作字符串工具类封装,Redis工具类封装 >>>>>>>>>>>>>>>>>>& ...

  6. java中文件操作的工具类

    代码: package com.lky.pojo; import java.io.BufferedReader; import java.io.BufferedWriter; import java. ...

  7. Java操作Redis工具类

    依赖 jar 包 <dependency> <groupId>redis.clients</groupId> <artifactId>jedis< ...

  8. ASP.NET实现二维码 ASP.Net上传文件 SQL基础语法 C# 动态创建数据库三(MySQL) Net Core 实现谷歌翻译ApI 免费版 C#发布和调试WebService ajax调用WebService实现数据库操作 C# 实体类转json数据过滤掉字段为null的字段

    ASP.NET实现二维码 using System;using System.Collections.Generic;using System.Drawing;using System.Linq;us ...

  9. 自制php操作mysql工具类(DB.class.php)

    DB.class.php <?php class DB{ //主机地址 var $host; //用户名 var $username; //密码 var $password; //数据库名 va ...

  10. java操作excel 工具类

    java操作excel 可参考https://blog.csdn.net/xunwei0303/article/details/53213130 直接上代码: 一.java生成excel文件: pac ...

随机推荐

  1. eclipse更改jdk版本(1.6》1.7 以此类推)

    电脑装了两个版本的JDK,在开发项目的时候默认使用的是高版本的,但是公司又要求用低版本的JDK来编译,肿么办???么事,小编这就来给你支招! eclipse 安装两个版本的JDK 1 打开eclips ...

  2. map json 字符串 对象之间的相互转化

    1.对象与字符串之间的互转 将对象转换成为字符串 String str = JSON.toJSONString(infoDo); 字符串转换成为对象 InfoDo infoDo = JSON.pars ...

  3. 本地存储API

    一.定义 随着互联网的快速发展,基于网页的应用越来越普遍,同时也变得越来越复杂,为了满足各种各样的需求,会经常在本地存储大量的数据,HTML5规范提出了相关解决方案 本地存储设置读取方便,容量较大,s ...

  4. 洛谷 P2363 马农

    题目描述 分别枚举两个矩阵?那样n^6太要命了. 可以枚举两个矩形的交点 将交点看成原点,可以将整个区域分成四个象限,1与3对应,2与4对应 再枚举相对应的象限计算可以获得的利益,用hash判重 可枚 ...

  5. P4425 【[HNOI/AHOI2018]转盘】

    颂魔眼中的一眼题我大湖南竟无一人\(AC\) 首先我们考虑一个性质:我们肯定存在一种最优解,满足从某个点出发,一直往前走,不停下来. 证明:我们假设存在一种最优解,是在\(t_i\)的时候到达\(a\ ...

  6. linux系列目录

    一:linux系列部分  linux系列(一):ls命令 linux系列(二):cd命令 linux系列(三):pwd命令 linux系列(四):mkdir命令 linux系列(五):rm命令 lin ...

  7. subcode

    在思考.查阅subcode时,我发现Magma,Sage Math软件都提供了具体的命令和例子,对subcode的认识比较具象. 例如:Sage Math中有如下命令: C1 = codes.Hamm ...

  8. shell编程题(一)

    求2个数之和 #!/bin/bash function add { )); then echo "The arg in't correct" else +$)) echo $sum ...

  9. 线程池(3)-参数-实现ThreadFactory

    1.介绍 ThreadFactory用来创建线程,需要实现newThread方法. 2.常用场景 线程重命名 设置守护进程 设置优先级 3.示例(线程重命名) public class ThreadF ...

  10. Java 冒泡排序算法

    public class StringSampleDemo { public static void main(String[] args) { int[] arr = {1, 2, -20, 20, ...