王朝网络
分享
 
 
 

通用查询组件设计

王朝delphi·作者佚名  2006-01-08
宽屏版  字体: |||超大  

通用查询组件设计

作者:nxyc_twz@163.com

在当前的MIS系统中,数据维护与数据查询是其两个核心功能。如何设计一个通用的查询组件,使开发的MIS系统中具备统一的查询界面,是MIS系统开发人员一直在偿试解决的问题。笔者在多年的MIS系统的开发设计过程中,经过不断的摸索与实践,终于设计完成了这套相对比较完善、通用的查询组件。

该组件继承自Tcomponet组件,主要包括一个查询窗体及一个显示查询摘要的窗体。主要设计思路是通过设置Tquery组件的Params(参数)以达到通用查询的目的。关于如何设计自定义组件,请参考:创建定制组件

现将其设计思路与技巧公布出来,与广大编程爱好者共勉。定义通用查询类

在指定字符串中查找字符串

function WordPos(const AWord, AString: string): Integer;

//在指定字符串中查找字符串

var s: string;

i, p: Integer;

begin

s := ' ' + AnsiUpperCase(AString) + ' '; //忽略大小写

for i := 1 to Length(s) do if not (s[i] in Identifiers) then s[i] := ' '; //常量定义

p := Pos(' ' + AnsiUpperCase(AWord) + ' ', s);

Result := p;

end;

定义通用查询类

type

TDBFilterDialog = class(TComponent)

PRivate

FDialog : TMyDBFilterDialog;//查询窗体类

FOriginalSQL : TStrings;//原来的SQL语句

FModifiedSQL : TStrings;//修改后的SQL语句

FDataSet : TQuery;//数据集

FDefaultMatchType : TDBFilterMatchType;//过滤类型

FOptions : TDBOptions;//过滤选项

FCaption: String;//窗体标题

FFields: TStringList;//字段列表

FOriginalVariables : TList;//变量列表

SQLProp : String;//SQL属性

procedure SetDataSet(const Value: TQuery);//设置数据集

procedure SetOptions(const Value: TDBOptions);//设置选项

procedure SetCaption(const Value: String);//设置标题

procedure SetDefaultMatchType(const Value: TDBFilterMatchType);//设置默认的匹配类型

procedure SetFields;//设置字段

procedure SetFieldsList(const Value: TStringList);//设置字段列表

procedure SetOriginalSQL(const Value: TStrings);//设置SQL

procedure RestoreSQL;//恢复SQL

procedure SaveParamValues;//保存参数值

{ Private declarations }

protected

{ Protected declarations }

procedure Loaded; override;//装载过滤对话框

procedure Notification(AComponent: TComponent;

Operation: TOperation); override;//传送消息

property OriginalSQL : TStrings read FOriginalSQL write SetOriginalSQL;

public

{ Public declarations }

constructor Create(AOwner : TComponent); override;//构造函数

destructor Destroy; override;//析构函数

function Execute : Boolean;//执行查询

procedure ReBuildSQL;//重建SQL语句

property ModifiedSQL : TStrings read FModifiedSQL;

published

{ Published declarations }

property Caption : String read FCaption write SetCaption;//设置标题

property DataSet : TQuery read FDataSet write SetDataSet;//设置数据集

property DefaultMatchType : TDBFilterMatchType read FDefaultMatchType write SetDefaultMatchType

default fdMatchStart;//过滤类型

property Options : TDBOptions read FOptions write SetOptions default

[fdShowCaseSensitive, fdShowNonMatching];//过滤选项

property Fields : TStringList read FFields write SetFieldsList;

end;

定义参数数据变量类

TDBVariable = class //参数数据变量

public

VariableName : String; //变量名

VariableValue : Variant; //变量值

constructor Create(name : String; value : Variant); //构造函数,设置变量名及变量值

end;

构造函数,设置变量名及变量值

constructor TDBVariable.Create(name: String; value : Variant);

begin

//构造函数,设置变量名及变量值

VariableName := name;

VariableValue := value;

end;

常量定义

const

Identifiers = ['a'..'z', 'A'..'Z', '0'..'9', '_', '#', '$', '.', '"', '@'];

procedure Register;//注册组件

注册组件

procedure Register;

//注册组件

begin

RegisterComponents('我的数据库组件', [TDBFilterDialog]);

end; {of Register}

过滤类型

//过滤的匹配类型:完全匹配、起始处匹配、结束处匹配、任意位置匹配、范围匹配、不匹配

TDBFilterMatchType = (fdMatchExact, fdMatchStart, fdMatchEnd,

fdMatchAny, fdMatchRange, fdMatchNone);

过滤选项

//过滤选项:大小写敏感显示大小写敏感显示不匹配记录

TDBOption = (fdCaseSensitive, fdShowCaseSensitive, fdShowNonMatching);

TDBOptions = Set of TDBOption;

设置数据集

procedure TDBFilterDialog.SetDataSet(const Value: TQuery);

begin

//设置数据集

if not ((Value is TQuery) or (Value = nil)) then//如果未指定数据集或指定的数据集不是Tquery,则发出异常

Raise Exception.Create(SDBFilterNonDBError);

//否则

FDataSet := Value;

SQLProp := 'SQL';

if ([csDesigning, csLoading] * ComponentState) = [] then

begin

SetFields;//设置字段

OriginalSQL := TStrings(GetOrdProp(FDataSet, SQLProp));//

end;

end;

设置选项

procedure TDBFilterDialog.SetOptions(const Value: TDBOptions);

begin

//设置选项

FOptions := Value;

end;

设置标题

procedure TDBFilterDialog.SetCaption(const Value: String);

begin

//设置标题

FCaption := Value;

FDialog.Caption := FCaption;

end;

(未完待续)

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有