伴随着时间的不断流逝,运用过进销存、连锁店软件、免费进销存软件、服装店软件等管理软件的客户都知道,随着时间的不断流逝,其下的管理软件系统数据也越来越多,一定程度上会阻碍数据库管理系统的运行速度,这时我们需要运用一些方法来优化它,从而提高数据库程序的运行效率。在此,秘奥软件站长网集了一种优化方法供大这参考。
假设有一个名为employee的表,现在我们要从其中查询数据,条件有三个,由用户动态选择,如:Name=A,Sex=B,Age=C
其中条件A、B、C之间是与的关系,A、B、C均为动态选择,可以取其中的一个、两个或三个,也可以一个都不选,当三个条件都不选择时则认为是无条件查询,按照通常的做法,最终的结果有8个,即有8条查询语句,分别是
1.select * from employee;
2.select * from employee where Age =C ;
3.select * from employee where Sex=B;
4.select * from employee where Sex=B and Age=C;
5.select * from employee where Name=A;
6.select * from employee where Name=A and Age=C;
7.select * from employee where Name=A and Sex=B ;
8.select * from employee where Name=A and Sex=B and Age=C;
显然这是比较烦琐的,而且用到了多重嵌套IF语句,因而在条件增多时,其复杂程度将大大增加。我们对它进行优化,方法如下:
首先定义一个字符串Str_Result用来存放组合条件的结果,开始时为空。用秘奥数据库系统程序语言描述如下:
if A <> "" then
Str_Result="where Name =A"
end if
if B <> "" then
if Str_Result="" then
Str_Result="where Sex=B"
else
Str_Result=Str_Result+"and Sex = B"
end if
end if
if C <> "" then
if Str_Result="" then
Str_Result="where Age =C"
else
Str_Result=Str_Result+"and Age=C"
end if
end if
最终的结果查询语句为:select * from employee + Str_Result。显然,这种方法减少了组合的分支和if语句的多重嵌套,从而提高了程序的效率。经秘奥软件站长了解本方法的原理在于定义了一个单独的字符串来表示组合的结果,当该字符串经过条件A后其值为A的条件,经过条件B后其值则为条件A与B 组合的结果,而当经过条件C后其值则变成条件A、B、C的组合,从而减少了组合判断的分支,对于更多条件的组合,在秘奥进销存、连锁店软件、免费进销存软件、服装店软件等管理软件中,其效能将更加明显。
文章来源:秘奥软件网,中小企业信息化领跑者!全国咨询热线:400-9908-527_www.misall.com
Copyright @ 2007 MISALL Corporation. All Rights Reserved. All Powered By
粤ICP备07050206号
地址:广州天河区大观南路26号长盛商务大厦B713、715 电话:020-28269517