SQL整理六


员工业绩表:inwork
+----+------------+----------+------------+
| id sname smoney sprovice
+----+------------+----------+------------+
| 1 zhangsan 2098 A
+----+------------+----------+------------+
| 2 lishi 3000 B
+----+------------+----------+------------+
| 3 wangwu 6789 C
+----+------------+----------+------------+
| 4 liumazi 4587 C
+----+------------+----------+------------+
| 5 dongjiu 3298 B
+----+------------+----------+------------+
| 6 shiga 4567 A
+----+------------+----------+------------+
| 7 heiqi 4007 A
+----+------------+----------+------------+
| 8 diuba 3500 B
+----+------------+----------+------------+
| 9 behkanm 2900 C
+----+------------+----------+------------+
SQL:
+-------------------------------------------------------+
CREATE TABLE IF NOT EXISTS `inwork` (
`id` int(11) NOT NULL auto_increment,
`sname` varchar(20) default NULL,
`smoney` int(11) default NULL,
`sprovice` varchar(12) default NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=7 ;

INSERT INTO `inwork` VALUES (1, 'zhangsan', 2098, 'A');
INSERT INTO `inwork` VALUES (2, 'lishi', 3000, 'B');
INSERT INTO `inwork` VALUES (3, 'wangwu', 6789, 'C');
INSERT INTO `inwork` VALUES (4, 'liumazi', 4587, 'C');
INSERT INTO `inwork` VALUES (5, 'dongjiu', 3298, 'B');
INSERT INTO `inwork` VALUES (6, 'shiga', 4567, 'A');
INSERT INTO `inwork` VALUES (7, 'heiqi', 4007, 'A');
INSERT INTO `inwork` VALUES (8, 'diuba', 3500, 'B');
INSERT INTO `inwork` VALUES (9, 'behkanm', 2900, 'C');
+-------------------------------------------------------+

要求:
1.显示出业绩大于同一地区业绩值最大的合同id ,姓名,地区,业绩
+-------------------------------------------+
|SELECT a.id, a.sname, a.smoney, a.sprovice |
|FROM inwork a, ( |
| SELECT max( smoney ) AS maxmoney, sprovice|
| FROM inwork |
| GROUP BY sprovice |
|)b |
|WHERE a.smoney = b.maxmoney |
|AND a.sprovice = b.sprovice |
+-------------------------------------------+
2.显示出业绩大于同一地区平均值的合同id ,姓名,地区,业绩
+-------------------------------------------+
|SELECT a.id, a.sname, a.smoney, a.sprovice |
|FROM inwork a, ( |
| SELECT avg( smoney ) AS avgmoney, sprovice|
| FROM inwork |
| GROUP BY sprovice |
|)b |
|WHERE a.smoney > b.avgmoney |
|AND a.sprovice = b.sprovice |
+-------------------------------------------+
3.把同一地区的平均业绩,地区插入到新表中(新表只包含两个字段即:平均业绩和地区)
+-------------------------------------------+
|create table t1 as( |
| select avg(smoney) AS avgmoneys, sprovice |
| from inwork |
| group by sprovice) ; |
+-------------------------------------------+

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值