热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

sql练习

--DROPTABLEIFEXISTS`dept`;--CREATETABLE`dept`(--`deptno`intPRIMARYKEY,--`dename`VARCHAR(14
-- DROP TABLE IF EXISTS `dept`;
-- CREATE TABLE `dept` (
-- `deptno` int PRIMARY KEY ,
-- `dename` VARCHAR(14) ,
-- `loc` VARCHAR(13)
-- );
-- 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‘);
--
--
-- DROP TABLE IF EXISTS emp;
-- CREATE TABLE emp (
-- empno int PRIMARY KEY,
-- ename VARCHAR(10),
-- job VARCHAR(9),
-- mgr INT,
-- hiredare DATE,
-- sal DOUBLE,
-- comm DOUBLE,
-- deptno INT
-- );
-- ALTER TABLE emp ADD CONSTRAINT FOREIGN KEY emp(deptno) REFERENCES dept (deptno);
-- INSERT INTO EMP VALUES(7369,‘SMITH‘,‘CLERK‘,7902,"1980-12-17",800,NULL,20);
--
-- INSERT INTO EMP VALUES(7499,‘ALLEN‘,‘SALESMAN‘,7698,‘1981-02-20‘,1600,300,30);
--
-- INSERT INTO EMP VALUES(7521,‘WARD‘,‘SALESMAN‘,7698,‘1981-02-22‘,1250,500,30);
--
-- INSERT INTO EMP VALUES(7566,‘JONES‘,‘MANAGER‘,7839,‘1981-04-02‘,2975,NULL,20);
--
-- INSERT INTO EMP VALUES(7654,‘MARTIN‘,‘SALESMAN‘,7698,‘1981-09-28‘,1250,1400,30);
--
-- INSERT INTO EMP VALUES(7698,‘BLAKE‘,‘MANAGER‘,7839,‘1981-05-01‘,2850,NULL,30);
--
-- INSERT INTO EMP VALUES(7782,‘CLARK‘,‘MANAGER‘,7839,‘1981-06-09‘,2450,NULL,10);
--
-- INSERT INTO EMP VALUES(7788,‘SCOTT‘,‘ANALYST‘,7566,‘1987-07-03‘,3000,NULL,20);
--
-- INSERT INTO EMP VALUES(7839,‘KING‘,‘PRESIDENT‘,NULL,‘1981-11-17‘,5000,NULL,10);
--
-- INSERT INTO EMP VALUES(7844,‘TURNER‘,‘SALESMAN‘,7698,‘1981-09-08‘,1500,0,30);
--
-- INSERT INTO EMP VALUES(7876,‘ADAMS‘,‘CLERK‘,7788,‘1987-07-13‘,1100,NULL,20);
--
-- INSERT INTO EMP VALUES(7900,‘JAMES‘,‘CLERK‘,7698,‘1981-12-03‘,950,NULL,30);
--
-- INSERT INTO EMP VALUES(7902,‘FORD‘,‘ANALYST‘,7566,‘1981-12-03‘,3000,NULL,20);
--
-- INSERT INTO EMP VALUES(7934,‘MILLER‘,‘CLERK‘,7782,‘1981-01-23‘,1300,NULL,10);
-- DROP TABLE IF EXISTS salgrade;
-- CREATE TABLE salgrade (
-- grade INT,
-- losal DOUBLE,
-- hisal DOUBLE
-- );
-- INSERT INTO SALGRADE VALUES (1,700,1200);
--
-- INSERT INTO SALGRADE VALUES (2,1201,1400);
--
-- INSERT INTO SALGRADE VALUES (3,1401,2000);
--
-- INSERT INTO SALGRADE VALUES (4,2001,3000);
--
-- INSERT INTO SALGRADE VALUES (5,3001,9999);

-- 1、查询部门30中员工的详细信息
-- SELECT * from emp WHERE deptno=30;
-- 2、找出从事clerk工作的员工的编号、姓名、部门号
-- SELECT empno ,ename,deptno from emp WHERE job=‘CLERK‘;
-- 3、检索出奖金多于基本工资的员工信息
-- SELECT * from emp where comm > sal;
-- 4、检索出奖金多余基本工资60%的员工
-- SELECT * FROM emp where comm >sal*0.6
-- 5、找出10部门的经理,20部门的员工信息
-- SELECT * from emp where deptno=10 AND job=‘manager‘ or deptno=20 AND job=‘clerk‘;
-- 6、找出10部门的经理,20部门的员工信息或既不属于经理也不属于职员,但工资高于2000的员工
-- SELECT * from emp where deptno=10 AND job=‘manager‘ or deptno=20 AND job=‘clerk‘ or job not in(‘manager‘,‘clerk‘) AND sal>2000;
-- 7、找出获得奖金的员工
-- SELECT * from emp WHERE comm >0
-- 8、找出奖金少于100或没有获得奖金的人
-- SELECT * from emp WHERE comm<100 or comm is null
-- 9、找出姓名以ABS开头的员工
-- SELECT * from emp WHERE ename like ‘a%‘ or ename like ‘b%‘ or ename like ‘s%‘
-- 10、找到名字长度为6个字符的员工
-- SELECT * from emp WHERE length(ename)=6
-- 11、找出名字中不包含r的员工
-- SELECT * from emp WHERE ename not like ‘%r%‘
-- 12、返回员工的信息,并按照姓名进行排序
-- SELECT * from emp  ORDER BY ename asc
-- 13、按照工作降序、工资升序排列
-- SELECT * from emp ORDER BY job desc , sal asc
-- 14、计算员工的日薪资
-- SELECT ename,sal/30 as ‘avg(sal)‘ from emp
-- 15、找出姓名中包含a的员工
-- SELECT * from emp WHERE ename LIKE ‘%a%‘
-- 16、返回拥有员工的部门名和部门号
-- SELECT a.ename,a.deptno,b.dename from emp a LEFT JOIN dept b on a.deptno=b.deptno
-- 17、工资水平多于smith的员工信息。
-- SELECT *FROM emp WHERE sal > (SELECT sal from emp WHERE ename=‘smith‘)
-- 18、返回员工和所属经理的姓名。
-- SELECT a.ename,b.ename from emp a LEFT JOIN emp b on a.mgr=b.empno WHERE b.job=‘manager‘
-- 19、返回雇员的雇佣日期早于其经理雇佣日期的员工及其经理姓名。
-- SELECT a.ename,b.ename from emp a  INNER JOIN emp b on a.mgr=b.empno WHERE a.hiredare-- 20、返回员工姓名及其所在的部门名称。
-- SELECT a.ename,b.dename FROM emp a LEFT JOIN dept b on a.deptno=b.deptno
-- 21、返回从事clerk工作的员工姓名和所在部门名称。
-- SELECT a.ename,b.dename from emp a LEFT JOIN dept b on a.deptno=b.deptno WHERE a.job=‘clerk‘
-- 22、返回部门号及其本部门的最低工资。
-- SELECT deptno,min(sal) from emp  GROUP BY deptno
-- 23、返回销售部(sales)所有员工的姓名。
-- SELECT a.ename from  emp a LEFT JOIN dept b on a.deptno=b.deptno WHERE b.dename=‘sales‘
-- 24、返回工资水平多于平均工资的员工。
-- SELECT * from emp WHERE sal> (SELECT avg(sal) FROM emp)
-- 25、返回与SCOTT从事相同工作的员工。
-- SELECT * from emp WHERE job in(  SELECT a.job from emp a WHERE a.ename=‘scott‘)
-- 26、返回与30部门员工工资水平相同的员工姓名与工资。
-- SELECT * from emp WHERE sal in(SELECT sal from emp WHERE deptno=30)
-- 27、返回部门号、部门名、部门所在位置及其每个部门的员工总数。   
-- SELECT a.deptno,b.dename,b.loc,count(*) as cc from emp a LEFT JOIN dept b on a.deptno=b.deptno GROUP BY a.deptno
-- 26、返回员工的姓名、所在部门名及其工资。
-- SELECT a.ename,b.dename,a.sal from emp a ,dept b WHERE a.deptno=b.deptno
-- 27、返回员工的详细信息。(包括部门名)
-- SELECT * from emp,dept,salgrade WHERE emp.deptno=dept.deptno AND emp.sal BETWEEN losal AND hisal
-- 28、返回员工工作及其从事此工作的最低工资。
-- SELECT * ,min(sal) from emp GROUP BY job
-- 29、返回不同部门经理的最低工资。
-- SELECT * ,min(sal) FROM emp WHERE job=‘manager‘  GROUP BY deptno
-- 30、计算出员工的年薪,并且以年薪排序
-- SELECT *,sal*12 as nianxin from emp ORDER BY nianxin  asc
-- 31、返回工资处于第四级别的员工的姓名。
-- SELECT * from emp a ,salgrade b WHERE a.sal BETWEEN losal AND hisal  AND grade=4
-- 32、返回工资为二等级的职员名字、部门所在地、和二等级的最低工资和最高工资
-- SELECT * FROM emp a ,salgrade b,dept c WHERE sal BETWEEN losal AND hisal AND grade=2  AND a.deptno=c.deptno
-- 33、返回工资为二等级的职员名字、部门所在地、二等级员工工资的最低工资和最高工资
-- SELECT ename,loc ,(SELECT min(sal) from emp,salgrade WHERE sal BETWEEN losal and hisal AND grade=2),(SELECT max(sal) from emp,salgrade WHERE sal BETWEEN losal and hisal AND grade=2)
-- from  emp ,dept ,salgrade WHERE sal BETWEEN  losal AND hisal AND grade=2 AND emp.deptno=dept.deptno
-- 34、工资等级多于smith的员工信息。
--   SELECT * from emp WHERE sal>(SELECT hisal FROM emp ,salgrade WHERE ename=‘smith‘ AND sal BETWEEN losal AND hisal)
-- select * from emp,salgrade where sal between losal and hisal and grade >(select grade from emp,salgrade where sal between losal
--  and hisal and ename = ‘smith‘);

sql 练习


推荐阅读
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 本文介绍了指针的概念以及在函数调用时使用指针作为参数的情况。指针存放的是变量的地址,通过指针可以修改指针所指的变量的值。然而,如果想要修改指针的指向,就需要使用指针的引用。文章还通过一个简单的示例代码解释了指针的引用的使用方法,并思考了在修改指针的指向后,取指针的输出结果。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • Monkey《大话移动——Android与iOS应用测试指南》的预购信息发布啦!
    Monkey《大话移动——Android与iOS应用测试指南》的预购信息已经发布,可以在京东和当当网进行预购。感谢几位大牛给出的书评,并呼吁大家的支持。明天京东的链接也将发布。 ... [详细]
author-avatar
weiwei
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有