Delphi(Tuxedo,BDE,ADO)三合一数据集组件HsTxQuery
Delphi(Tuxedo,BDE,ADO)三合一数据集组件HsTxQuery
一、背景
为什么要做这个三合一数据集组件呢?曾经我们公司用delphi开发的系统大多以ADO,BDE方式来连接数据库,这两套组件使用十分方便和灵活,对成本控制也十分友好,从曾经十多年间使用情况来看问题都不大,用户也没有三层架构的要求。但在今年投标大公司的项目时,往往会被技术要求阻拦,为什么呢?甲方的标书上写着要三层架构,这令我们十分头疼,眼下我们公司是使用Tuxedo来做中间层,假设改造,那么成本估计是一年的时间,二个版本号的维护成本也是十分高昂。面对这样的情况,我提出三合一的思路,即构建新数据集组件。新组件兼容曾经Query的所有属性和方法,仅仅需使用UE编辑器替换曾经Query类就能够了,并能够在Tuxedo,BDE,ADO三种连接方式间进行切换,系统也不用另外维护一个版本号。思疏才浅,希望大家多多不吝赐教,感激不尽。
二、组件结构图
从结构图中能够看到使用了装饰模式,HsTxQuery将用户的訪问对象放在了自己的身后,依据连接方式转发给不同对象。它訪问Tuxedo是通过HsTxQuery.dll訪问,中间有一层转换,而BDE、ADO是直接连接。
三、设计类
四、样例
1、 打开
procedure TForm1.Button7Click(Sender: TObject); begin HsQuery2.close; HsQuery2.SQL.Text := 'select * from users'; HsQuery2.Open; end; |
2、 运行
procedure TForm1.Button7Click(Sender: TObject); begin HsQuery2.close; HsQuery2.SQL.Text := 'insert test value(1,2,3)'; HsQuery2. ExecSQL; end; |
3、 插入记录
procedure TForm1.Button9Click(Sender: TObject); var ms : TMemoryStream; begin ms := TMemoryStream.Create; Image2.Picture.Graphic.SaveToStream(ms); with HsQuery2 do begin database.StartTransaction; Append; HsQuery2.FieldByName('f1').AsString := FormatDateTime('YYYYMMDDHHMMSS',now); HsQuery2.FieldByName('f2').AsString := FormatDateTime('YYYYMMDD',now); HsQuery2.FieldByName('f3').AsString := FormatDateTime('HHMMSS',now); HsQuery2.FieldByName('f4').AsString := '潇洒哥'; HsQuery2.FieldByName('f5').AsString := '1'; HsQuery2.FieldByName('f6').AsString := '330102199001164317'; HsQuery2.FieldByName('f7').AsString := '1'; HsQuery2.SetBlobStream(HsQuery2.FieldByName('fPHOTO'),ms); Post; ApplyUpdates; CommitUpdates; database.Commit; end; ms.Free; end; |
4、 更新记录
procedure TForm1.Button10Click(Sender:TObject); var ms: TMemoryStream; begin ms:= TMemoryStream.Create; Image2.Picture.Graphic.SaveToStream(ms); HsQuery2.Edit; HsQuery2.Fields.Fields[0].AsString := '6'; HsQuery2.Fields.Fields[1].AsInteger := 198; HsQuery2.Fields.Fields[2].AsString := ''; HsQuery2.Fields.Fields[3].AsString := 'Roy'; HsQuery2.Fields.Fields[4].AsString := '1'; HsQuery2.Fields.Fields[5].AsString := '2'; HsQuery2.SetBlobStream(HsQuery2.Fields.Fields[6],ms); HsQuery2.Post; HsQuery2.ApplyUpdates; HsQuery2.CommitUpdates; ms.Free; end; |
5、 删除记录
HsQuery2.Delete; |
6、 存/取Blob数据
存,查看插入样例。
procedure TForm1.Button8Click(Sender: TObject); var Stream:TMemoryStream; Jpg:TjpegImage; begin Stream:=HsQuery2.GetBlobStream(HsQuery2.FieldByName('DATA')) ; Jpg:=TjpegImage.Create ; Stream.Position :=0; jpg.LoadFromStream(Stream); // 载入图片 image2.Picture.Assign(Jpg); end; |
7、 获取字段值
procedure TForm1.Button15Click(Sender: TObject); begin ShowMessage(hsQuery2.FieldByName('userid').AsString); ShowMessage(hsQuery2.Fields.Fields[0].AsString); end; |
8、 过滤
//以下是过滤 hsQuery2.Filter := 'userid=102'; hsQuery2.Filtered := true; //以下是反过滤 hsQuery2.Filter := ''; hsQuery2.Filtered := true; |
9、 參数
/ procedure TForm1.Button16Click(Sender: TObject); begin with hsquery2 do begin close; sql.clear; sql.Text := 'Select * From users where USERID = :id'; ParamByName('id').value := 106; open; end; end; |
10、 Tuxedo、BDE和ADO模式动态切换
/ procedure TForm1.ComboBox1Change(Sender: TObject); begin case combobox1.ItemIndex of 0 : begin hsQuery2.DatasetType := dtTuxedo; hsQuery2.ConnectionString := '//192.168.1.121:8887'; end; 1 : begin hsQuery2.DatasetType := dtBDE; hsQuery2.ConnectionString := 'orcl'; hsQuery2.Connection := Database1; end; 2 : begin hsQuery2.DatasetType := dtADO; hsQuery2.ConnectionString := 'Provider=OraOLEDB.Oracle.1;Password=gf;Persist Security Info=True;User ID=gf;Data Source=orcl;Extended Properties=""'; hsQuery2.Connection := ADOConnection1; end; end; end; |
五、展望
非常多进行数据换的中间件(如各种MQ)都能够封装成易用的组件,使开发员生活更美好。
开发样例请增加QQ群:69024049 进行索取和讨论。
Delphi(Tuxedo,BDE,ADO)三合一数据集组件HsTxQuery的更多相关文章
- Delphi中封装ADO之我重学习记录
delphi adodataset ctstatic 数据是缓存在服务器端还是客户端 答:客户端,开启本地缓存功能后,就能数据在本地批量修改后,再批量提交,减少了网络传送 原创,专业,图文 Del ...
- 升讯威ADO.NET增强组件(源码):送给喜欢原生ADO.NET的你
目前我们所接触到的许多项目开发,大多数都应用了 ORM 技术来实现与数据库的交互,ORM 虽然有诸多好处,但是在实际工作中,特别是在大型项目开发中,容易发现 ORM 存在一些缺点,在复杂场景下,反而容 ...
- GitHub开源:升讯威ADO.NET增强组件 sheng.ADO.NET.Plus V1.3
GitHub: https://github.com/iccb1013/sheng.ADO.NET.Plus 早前分享过,当时没有把代码上传到Github,只是通过邮件的形式分享给了部分需要的朋友,最 ...
- 浅谈控件(组件)制作方法一(附带一delphi导出数据到Excel的组件实例)(原创)
来自:http://blog.csdn.net/zhdwjie/article/details/1490741 -------------------------------------------- ...
- Delphi中JSon SuperObject 使用:数据集与JSON对象互转
在delphi中,数据集是最常用数据存取方式.因此,必须建立JSON与TDataSet之间的互转关系,实现数据之间通讯与转换.值得注意的是,这只是普通的TDataset与JSON之间转换,由于CDS包 ...
- WebForm获取GET或者POST参数到实体的转换,ADO.NET数据集自动转换实体
最近在修改维护以前的webform项目(维护别人开发的.....)整个aspx没有用到任何的控件,这个我也比较喜欢不用控件所以在提交信息的时候需要自己手动的去Request.QueryString[] ...
- 用Setup Factory7.0怎样打包delphi的BDE?
BDE打包发布实例操作步骤如下: 使用软件:Setup Factory 7.0打包 把C:\Program Files\Common Files\Borland Shared中的所有文件和你的开发的应 ...
- DELPHI 调用系统 ADO 配置窗体 提高软件易用性
最近DELPHI好像不太景气哦,把自己的代码拿出来晒晒.高手别喷哦. 直接上代码 implementation uses AdoConEd; var saveconnstr:string; proc ...
- Delphi TScrollBar 用于滚动窗口、组件内容
滚动条组件(TScrollBar)此组件是一个Windows滚动条,用于滚动窗口.组件内容.许多控制有滚动条属性,它们把滚动条作为自己的一部分,对于没有完整滚动条的控制,TScrollBar组件提供了 ...
随机推荐
- CentOS7.3 下开放防火墙的端口
CentOS 7.3默认使用的是firewall作为防火墙,这里改为iptables防火墙. 1:关闭firewall: systemctl stop firewalld.service system ...
- 【转】 HTML解析:基于XPath的C#类库HtmlAgiliytyPack
[转] HTML解析:基于XPath的C#类库HtmlAgiliytyPack 最近处于毕业设计开始阶段,前期工作需要去国外的一些专业数据库网站比对一些所需TF家族信息,为了快捷方便,想到用程序去帮助 ...
- hdu 1005 Number Sequence(矩阵连乘+二分快速求幂)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1005 代码: #include<iostream> #include<stdio.h&g ...
- eclipse下Tomcat7.0启动奔溃问题
好久没用Eclipse了,如今上班这家公司正好用到了,完后用Tomcat启动项目一直报一个错,例如以下图 错误代码例如以下: watermark/2/text/aHR0cDovL2Jsb2cuY3Nk ...
- Ubuntu下安装git工具
环境:Ubuntu 9.10 git-1.8.2.3.tar.bz2 1.将安装包下载到所选文件夹下,如:/tmp 2.tar -xjf git-1.8.2.3.tar.bz2 3.cd git-1. ...
- css3中rem和em是干嘛的
css3中rem和em是干嘛的 一.总结 一句话总结:对rem综合评价是用来做web app它绝对是最合适的人选之一. 这里我特别强调web app,web page就不能使用rem吗,其实也当然可以 ...
- 仿即刻app"猜你喜欢"切换控件
最近在即刻里看到即刻的"猜你喜欢"的板块,觉得效果很赞. 当点击"换一换"时,上面三个条目程序切换效果,并且三个条目的切换以不同的速度进行. 于是开始想办法撸出 ...
- 简单缓存Cache
接口 interface ICache { /// <summary> /// 添加 /// </summary> /// <param name="key&q ...
- 负载均衡-lvs
常用的负载均衡技术比较DNS 轮询DNS本身的机制不再赘述,这里主要看一看基于DNS的负载均衡,其大致原理很清楚,DNS系统本身支持同一个域名映射到多个ip (A记录),例如 这样每次向DNS系统询问 ...
- HDU 4372 Count the Buildings
Count the Buildings Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Othe ...