2017-06-27
Where 是一个约束声明,使用Where约束来自数据库的数据,Where是在结果返回之前起作用的,Where中不能使用聚合函数。
Having是一个过滤声明,是在查询返回结果集以后对查询结果进行的过滤操作,在Having中可以使用聚合函数。
在查询过程中聚合语句(sum,min,max,avg,count)要比having子句优先执行。而where子句在查询过程中执行优先级高于聚合语句。
下面用一个例子进一步说明问题。假设有数据表: [sql] CREATE TABLE `test`.`salary_info` ( `id` int(10) unsigned NOT NULL auto_increment, `deparment` varchar(16) NOT NULL default '', `name` varchar(16) NOT NULL default '', `salary` int(10) unsigned NOT NULL default '0', PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
例1:要查找平均工资大于3000的部门 则sql语句应为: [sql] select deparment, avg(salary) as average from salary_info group by deparment having average > 3000 此时只能使用having,而不能使用where。一来,我们要使用聚合语句avg;二来,我们要对聚合后的结果进行筛选(average > 3000),因此使用where会被告知sql有误。
例2:要查询每个部门工资大于3000的员工个数 sql语句应为: [sql] select deparment, count(*) as c from salary_info where salary > 80 group by deparment 此处的where不可用having进行替换,因为是直接对库中的数据进行筛选,而非对结果集进行筛选。
趣味烘焙秀下载v187.1.1 安卓版
其它手游 72.18MB
下载
盖瑞模组机器人下载v1.66.1 安卓版
其它手游 145.89MB
下载
狂飙大卡车下载v1.0.7 安卓版
其它手游 18.75MB
下载
海洋连连消下载v1.0.7 安卓版
其它手游 19.07MB
下载
来切我呀下载v1.1.1 安卓版
其它手游 138.5MB
下载
猎手大追捕下载v187.1.1 安卓版
其它手游 116.76MB
下载
疯狂牛马实验室下载v2.0.1 安卓版
其它手游 79.88MB
下载
炮弹消消乐下载v0.251111.169 安卓版
其它手游 135.69MB
下载极限躲猫猫模拟下载v1.0 安卓版
下载
尸群突袭最新版下载v3 安卓版
下载
僵尸追逐游戏下载v2.1 安卓版
下载
钢铁山海经下载v1.0 安卓版
下载
水果萌萌消下载v1.0.1 安卓版
下载
恐怖童话故事下载v1.0 安卓版
下载
差不多英雄5.8.7破解版下载v5.8.7 安卓修改版
下载
差不多英雄内购破解版最新版下载v5.8.7 安卓中文版
下载