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组件提供了 ...
随机推荐
- cal---显示日历
cal命令用于显示当前日历,或者指定日期的日历. 语法 cal(选项)(参数) 选项 -l:显示单月输出: -3:显示临近三个月的日历: -s:将星期日作为月的第一天: -m:将星期一作为月的第一天: ...
- MAC下搭建appium UI自动化环境
参考资料: http://qa.blog.163.com/blog/static/190147002201510161119832/ http://blog.csdn.net/liuchunming0 ...
- 配置TL-WVR45G企业路由动态地址
1.打开浏览器,在地址栏输入http://192.168.1.1. 2.输入默认用户名密码:admin,登录. 3.[基本设置]->[lan设置]->[lan设置] ip地址改成:192 ...
- sql server 2000 自动收缩数据库大小
转载.......http://mars968.blog.163.com/blog/static/7400033200941642356258/ SQLServer2000压缩日志及数据库文件 ...
- 安装Signavio Web设计器
在Jbpm3版本号中,这个著名的开源项目并没有基于浏览器的图形化流程设计器,结果导致流程设计一直停留在CS阶段. 比方我之前做过的一个OA项目.项目中採用的就是Jbpm3.因为它不支持在浏览器中的图形 ...
- POJ1833 & POJ3187 & POJ3785 next_permutation应用
要是没有next_permutation这个函数,这些题认为还不算特别水,只是也不一定,那样可能就会有对应的模板了. 反正正是由于next_permutation这个函数.这些题包含之前的POJ122 ...
- vue2.0-elementUI
main.js import Vue from 'vue' import App from './App.vue' import ElementUI from 'element-ui' import ...
- UVA - 12263 Rankings 模拟(拓扑排序)
题意:1~n这n个数,给你一个初始的顺序,再告诉你那两个数的大小关系发生了变化,求变化后的 顺序,不存在则输出IMPOSSIBLE 思路:这题很遗憾没在比赛的时候过掉,结束后加了一行就AC了.题目真的 ...
- codeforces 710A King Moves(水)
output standard output The only king stands on the standard chess board. You are given his position ...
- 基于.NET平台常用的框架技术整理
个人整理 部分收藏于:http://www.cnblogs.com/hgmyz/p/5313983.html 自从学习.NET以来,优雅的编程风格,极度简单的可扩展性,足够强大开发工具,极小的学习曲线 ...