|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
我想详细了解ASP整站代码与PSP整站代码有什么优缺点,那个更好,更安全,更用容易维护,和管理。。。having子句与where有类似的地方但也有区分,都是设定前提的语句。在查询过程当中聚合语句(sum,min,max,avg,count)要比having子句优先实行.而where子句在查询过程当中实行优先级别优先于聚合语句(sum,min,max,avg,count)。
复杂说来:
where子句:
selectsum(num)asrmbfromorderwhereid>10
//只要先查询出id年夜于10的纪录才干举行聚合语句
having子句:
selectreportstoasmanager,count(*)asreportsfromemployees
groupbyreportstohavingcount(*)>4
以northwind库为例.having前提表达示为聚合语句。一定的说having子句查询历程实行优先级别低于聚合语句。
再换句措辞说把下面的having换成where则会堕落。统计分组数据时用到聚合语句。
对分组数据再次判别时要用having。假如不必这些干系就不存在利用having。间接利用where就好了。
having就是来填补where在分组数据判别时的不敷。由于where实行优先级别要快于聚合语句。
聚合函数,这是必须先讲的一种特别的函数:比方SUM,COUNT,MAX,AVG等。这些函数和别的函数的基本区分就是它们一样平常感化在多笔记录上。
SELECTSUM(population)FROMtablename
这里的SUM感化在一切前往纪录的population字段上,了局就是该查询只前往一个了局,即一切
国度的总生齿数。经由过程利用GROUPBY子句,可让SUM和COUNT这些函数对属于一组的数据起感化。
当你指定GROUPBYregion时,属于统一个region(区域)的一组数据将只能前往一行值.
也就是说,表中一切除region(区域)外的字段,只能经由过程SUM,COUNT等聚合函数运算后前往一个值.
HAVING子句可让我们选择成组后的各组数据
HAVING子句在聚合后对组纪录举行选择
而WHERE子句在聚合前先选择纪录.也就是说感化在GROUPBY子句和HAVING子句前
看上面这几个例子吧:
1、显现每一个区域的总生齿数和总面积
SELECTregion,SUM(population),SUM(area)
FROMbbc
GROUPBYregion
先以region把前往纪录分红多个组,这就是GROUPBY的字面寄义。分完组后,然后用聚合函数对每组中的分歧字段(一或多笔记录)作运算。
2、显现每一个区域的总生齿数和总面积.仅显现那些面积凌驾1000000的区域。
SELECTregion,SUM(population),SUM(area)
FROMbbc
GROUPBYregion
HAVINGSUM(area)>1000000
在这里,我们不克不及用where来选择凌驾1000000的区域,由于表中不存在如许一笔记录。
相反,HAVING子句可让我们选择成组后的各组数据.
结论:和PHP一样,ASP简单而易于维护,很适合小型网站应用,通过DCOM和MTS技术,ASP甚至还可以完成小规模的企业应用,但ASP的致命缺点就是不支持跨平台的系统,在大型项目开发和维护上非常困难。 |
|