mysql 基础列题
1:emp表中查询公司总共有几个部门
注意,会查询出来大量重复的,使用函数distinct
select distinct job from scott.emp;
2:查询公司工资在1000-3000之间的人有哪些
使用函数between ...and..
select * from scott.emp where sal between 3000 and 5000;
3:查询公司没有奖金的人
使用null 和“” 不一样
select * from scott.emp where comm is null;
4:查询公司员工职位是'manager','clerk' 的人
select * from scott.emp where lower(job) in('manager','clerk');
查询不是这两个职位的人
select * from scott.emp where upper(job) not in('MANAGER','CLERK');
5:查询工资最高的人
查询每个部门工资最高的人?--分组查询
select deptno,max(sal) from scott.emp group by deptno ;
完整版
29:-每个部门的最高薪水是多少
select * from scott.emp where (deptno,sal) in (select deptno,max(sal) from scott.emp group by deptno);
7:-查询比20部门总人数多的部门
select deptno from scott.emp group by deptno having count(*) >(select count(*) from scott.emp where deptno=20);
13:薪水由高到低排序( 降序排列 )
select empno,ename,sal from scott.emp order by sal desc;
14-按入职时间排序 , 入职时间越早排在前面
select hiredate from scott.emp order by hiredate;
15按部门排序 , 同一部门按薪水由高到低排序
select deptno,sal from scott.emp order by deptno,sal desc;
16计算员工的薪水总和是多少?sum()
select sum(sal)+sum(comm) from scott.emp;
17计算最早和最晚的员工入职时间
select min(hiredate),max(hiredate) from scott.emp;
(查最早和最晚入职的人的信息)
select * from emp where hireDate in (select max(hireDate) from emp)
UNION
select * from emp where hireDate in (select min(hireDate) from emp)
18按部门计算每个部门的最高和最低薪水分别是多少
select deptno,max(sal),min(sal) from scott.emp group by deptno order by deptno;
19计算每个部门的 薪水总和 和 平均薪水?
select deptno,sum(sal),avg(sal) from scott.emp group by deptno;
20按职位分组 , 每个职位的最高、最低薪水和人数?
select job,max(sal),min(sal),count(*) from scott.emp group by job;
21平均薪水大于5000元的部门数据`
select deptno,avg(sal) from scott.emp group by deptno having avg(sal)>2000;
22薪水总和大于20000元的部门数据
select deptno,sum(sal) from scott.emp group by deptno having sum(sal)>10000;
23:哪些职位的人数超过2个人
select job,count(*) from scott.emp group by job having count(*)>2;
24:查询最高薪水的是谁?-查询最低薪水的员工
select ename from scott.emp where sal=(select max(sal) from scott.emp);
25:谁的工资比smith高
select ename from scott.emp where sal>(select sal from scott.emp where lower(ename)='smith');
26销售部门有哪些职位存在
select job from scott.emp where deptno=(select deptno from scott.dept where lower(dname)='sales');
--思考:
-- 谁的工资比smith高这道题目中如果存在两个角simth的人会怎么样?
--all:满足全部
--any:任意一个
insert into scott.emp(empno,ename,sal) values(9527,'smith',888);
select ename from scott.emp where sal>all(select sal from scott.emp where lower(ename)='smith');
27-查询谁和smith是同一个部门的员工
select empno,ename,deptno from scott.emp where deptno=(select deptno from scott.emp where lower(ename)='smith');
28查询谁是员JAMES的下属
select empno,ename from scott.emp where mgr in(select mgr from scott.emp where lower(ename)='james');
30哪个部门的人数比部门20的人数多
select deptno,count(*) from scott.emp group by deptno having count(*)>
(select count(*) from scott.emp where deptno=20);
31:哪些员工的薪水比公司的平均薪水低?
select empno,ename from scott.emp where sal<(select avg(sal) from scott.emp);
--------------------------------------------华丽的分割线-----------------------------------------------------------------
Navicat MySQL Data Transfer 员工管理
Source Server : wode
Source Server Version : 50022
Source Host : localhost:3306
Source Database : j121
Target Server Type : MYSQL
Target Server Version : 50022
File Encoding : 65001
Date: 2016-05-09 10:33:00
*/
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for `dept`
-- ----------------------------
DROP TABLE IF EXISTS `dept`;
CREATE TABLE `dept` (
`deptNo` int(11) NOT NULL,
`dname` varchar(20) default NULL,
`loc` varchar(40) default NULL,
PRIMARY KEY (`deptNo`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
-- ----------------------------
-- Records of dept
-- ----------------------------
INSERT INTO dept VALUES ('10', 'accounting', 'new york');
INSERT INTO dept VALUES ('20', 'research', 'dallas');
INSERT INTO dept VALUES ('30', 'sales', 'chicago');
INSERT INTO dept VALUES ('40', 'operations', 'boston');
-- ----------------------------
-- Table structure for `emp`
-- ----------------------------
DROP TABLE IF EXISTS `emp`;
CREATE TABLE `emp` (
`id` int(11) NOT NULL auto_increment,
`empno` int(11) default NULL,
`eName` varchar(20) default NULL,
`job` varchar(10) default NULL,
`mgr` int(11) default NULL,
`hireDate` date default NULL,
`sal` decimal(7,2) default NULL,
`comm` decimal(7,2) default NULL,
`deptNo` int(11) default NULL,
PRIMARY KEY (`id`),
KEY `FK_emp_deptNo` (`deptNo`),
CONSTRAINT `FK_emp_deptNo` FOREIGN KEY (`deptNo`) REFERENCES `dept` (`deptNo`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
-- ----------------------------
-- Records of emp
-- ----------------------------
INSERT INTO emp VALUES ('1', '7369', 'smith', 'clerk', '7902', '1980-12-17', '800.00', null, '20');
INSERT INTO emp VALUES ('2', '7499', 'allen', 'salesman', '7698', '1981-02-20', '1600.00', '300.00', '30');
INSERT INTO emp VALUES ('3', '7521', 'ward', 'salesman', '7698', '1981-02-22', '1250.00', '500.00', '30');
INSERT INTO emp VALUES ('4', '7566', 'jones', 'manager', '7839', '1981-04-02', '2975.00', null, '20');
INSERT INTO emp VALUES ('5', '7654', 'martin', 'salesman', '7698', '1981-09-28', '1250.00', '1400.00', '30');
INSERT INTO emp VALUES ('6', '7698', 'blake', 'manager', '7839', '1981-05-01', '2850.00', null, '30');
INSERT INTO emp VALUES ('7', '7782', 'clark', 'manager', '7839', '1981-06-09', '2450.00', null, '10');
INSERT INTO emp VALUES ('8', '7788', 'scott', 'analyst', '7566', '1987-07-31', '3000.00', null, '20');
INSERT INTO emp VALUES ('9', '7839', 'king', 'president', null, '1981-11-17', '5000.00', null, '10');
INSERT INTO emp VALUES ('10', '7844', 'turner', 'salesman', '7698', '1981-09-08', '1500.00', '0.00', '30');
INSERT INTO emp VALUES ('11', '7876', 'adams', 'clerk', '7788', '1987-07-13', '1100.00', null, '20');
INSERT INTO emp VALUES ('12', '7900', 'james', 'clerk', '7698', '1981-12-03', '950.00', null, '30');
INSERT INTO emp VALUES ('13', '7902', 'ford', 'analyst', '7566', '1981-12-03', '3000.00', null, '20');
INSERT INTO emp VALUES ('14', '7934', 'miller', 'clerk', '7782', '1982-02-23', '1300.00', null, '10');
mysql 基础列题的更多相关文章
- mysql 基础,列类型
- 听我的,看完这30道MySQL基础题再去面试
可以微信搜索公众号「 后端技术学堂 」回复「1024」获取50本计算机电子书,回复「进群」拉你进读者技术交流群,文章每周持续更新,我们下期见! 一个典型的互联网产品架构包含接入层.逻辑处理层以及存储层 ...
- mysql基础: mysql列类型--字符串
mysql列类型:整型 http://blog.csdn.net/jk110333/article/details/9342283 mysql列类型--时间和日期 http://blog.csd ...
- mysql 基础之CURD
原文:mysql 基础之CURD 增删改查基本语法学习 增: insert Insert 3问: 1: 插入哪张表? 2: 插入哪几列? 3: 这几列分别插入什么值? Insert into Tabl ...
- Mysql基础代码(不断完善中)
Mysql基础代码,不断完善中~ /* 启动MySQL */ net start mysql /* 连接与断开服务器 */ mysql -h 地址 -P 端口 -u 用户名 -p 密码 /* 跳过权限 ...
- MYSQL基础操作
MYSQL基础操作 [TOC] 1.基本定义 1.1.关系型数据库系统 关系型数据库系统是建立在关系模型上的数据库系统 什么是关系模型呢? 1.数据结构可以规定,同类数据结构一致,就是一个二维的表格 ...
- mysql 基础篇5(mysql语法---数据)
6 增删改数据 -- ********一.增删改数据********* --- -- 1.1 增加数据 -- 插入所有字段.一定依次按顺序插入 INSERT INTO student VALUES(1 ...
- MySQL基础学习总结
1.MySQL基础概念 mysql逻辑架构如下: 每个客户端连接都会在服务器中拥有一个线程,这个连接的查询只会在这个单独的线程中执行. MySQL是分层的架构.上层是服务器层的服务和查询执行引擎,下层 ...
- MySQL基础(三)——约束
MySQL基础(三)--约束 约束是在表上强制执行的数据校验规则,主要用于维护表中数据的完整性以及当数据之间有以来关系时,保护相关的数据不会被删除. 根据约束对列的限制,可以划分为:单列约束(只约束一 ...
随机推荐
- DOM位置参数
以chrome浏览器测试为准 scrollwidth scrollheight clientwidth clientheight offsetwidth offsetheight 对象的实际宽高 包括 ...
- @font-face 的用法
现在很多设计用的字体都是五花八门的.我们切图又不能很好的让搜索爬虫搜索.就会使用@font-face方法: @Font-face目前浏览器的兼容性: Webkit/Safari(3.2+):TrueT ...
- maven 问题解决 tools以及jconsole两个jar包 无效
在SVN上下载项目,结果完成后出现两个jar包不存在的情况 如下图: 然后,第一步就是去查看POM.xml文件是否配置了这两个文件,结果并没有,于是就更加奇怪了 所以怀疑是不是其他maven下载的ja ...
- <textarea>使用的时候发现的两个问题的总结
在练习表单的过程中,使用<textarea>时,遇到2个问题: 1.文本开始前有好多空格. 原来的代码是这样的: <textarea row="20" col=& ...
- iOS学习之git的使用
SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是自己的电脑,所以首先要从中央服务器哪里得到最新的版本,然后干活,干完后,需要把自己做完的活推送到中央服务器.集中式版本控 ...
- 使用PowerDesigner导出MySQL数据库建模
数据库服务器在linux上面,客户端本子win8系统 1.安装odbc 1.1 下载odbc,http://dev.mysql.com/downloads/connector/odbc/ Windo ...
- SQL Server简单语句/待整理
数据库对象:表Table,视图View,存储过程Stored Procedure,触发器Trigger 关系:1关系=1二维表,1关系有1关系名.1关系=1表对象 属性/字段: 二维表中垂直方向的列 ...
- MyEclipse中直接打开class文件的方法
安装步骤: 1>下载jad.exe(这是一个class文件的反编译工具,但是是命令行运行编译,使用起来不是很方便:), 将其拷贝到%JAVA_HOME%/bin目录下(其他目录也可). 2> ...
- RABBITMQ(小总结 持续更新...
(一)理解消息通信 1.消息通信概念---消费者.生产者和代理 生产者(producer)创建消息,然后发送到代理服务器(RaabitMQ). 其中消息包括两部分内容:有效载荷(payload)和标签 ...
- U盘又中毒了,隐藏文件如何显示
在 开始--运行 中输入 cmd ,再输入,attrib -H -S D:\123 /s /d 后回车,你就发现问题解决了.注意命令之间的空格,D:\代表盘符,就是你的移动硬盘的盘符,如果你的盘符是E ...