dual 伪表 用来测试函数和表达式

1.查询EMP表中所有人的信息,结果格式样例为“某人的月薪是1000$”

  SELECT ENAME||'的月薪是'||SAL||'$' FROM EMP;

2.查询EMP表的部门号,去掉重复数据

  SELECT DISTINCT DEPTNO FROM EMP;

3.查询EMP表员工的姓名和年薪,年薪列用“ANNUAL”显示

  SELECT ENAME AS "姓名",SAL*12 AS "ANNUAL" FROM EMP;

4.描述employees表结构

  DESC EMPLOYEES;

5.查询EMPLOYEES表中的内容,预测每个员工姓名和月加薪10%之后的月薪,列名为“预测月薪”

  SELECT FIRST_NAME AS "姓名",SALARY*1.1 AS "预测月薪" FROM EMPLOYEES;

6.下面语句有四个编码错误,找出它们

SELECT EMPLOYEES_ID,LAST_NAME,SAL*12 ANNUAL SALARY FROM EMPLOYEES;

  LAST_NAME 后面没有逗号 sal*12后面没有AS 应该是SALARY ANNUAL SALARY缺少双引号

7.用两种方式写出 FIRST_NAME.LAST_NAME 月薪在2000-3000之间的

  SELECT FIRST_NAME||'.'||LAST_NAME FROM EMPLOYEES WHERE SALARY BETWEEN 2000 AND 3000;

  SELECT FIRST_NAME||'.'||LAST_NAME FROM EMPLOYEES WHERE SALARY >=2000 AND SALARY<=3000;

8.显示工资为2000,3000,4000,5000的FIRST_NAME.LAST_NAME

  SELECT FIRST_NAME||'.'||LAST_NAME FROM EMPLOYEES WHERE SALARY IN(2000,3000,4000,5000);

9.FIRST_NAME是以S开头的所有的数据

  SELECT * FROM EMPLOYEES WHERE FIRST_NAME LIKE 'S%';

10.FIRST_NAME是以s结尾的所有的数据

  SELECT * FROM EMPLOYEES WHERE FIRST_NAME LIKE '%s';

11.FIRST_NAME第三个字母是a的所有的数据

  SELECT * FROM EMPLOYEES WHERE FIRST_NAME LIKE '__a%';

12.FIRST_NAME倒数第三个字母是a的所有的数据

  SELECT * FROM EMPLOYEES WHERE FIRST_NAME LIKE '%a__';

13.显示第三个字母是下划线的

  SELECT * FROM T1 WHERE X LIKE '__\_%' ESCAPE '\';

14.显示第五个字母是百分号的

  SELECT * FROM T1 WHERE X LIKE '____\%%' ESCAPE '\';

15.查询COMMISSION_PCT为非空的所有内容

  SELECT * FROM EMPLOYEES WHERE COMMISSION_PCT IS NOT NULL;

16.查询薪水大于一万和COMMISSION_PCT>0.3的所有内容

  SELECT * FROM EMPLOYEES WHERE SALARY>10000 AND COMMISSION_PCT>0.3;

17.查询薪水大于一万或者COMMISSION_PCT非空的所有内容

  SELECT * FROM EMPLOYEES WHERE SALARY>10000 OR COMMISSION_PCT IS NOT NULL;

18.查询部门ID不在80和90的所有内容

  SELECT * FROM EMPLOYEES WHERE DEPARTMENT_ID NOT IN (80,90);

19.按工资升序排列

  SELECT * FROM EMPLOYEES ORDER BY SALARY ASC;

20.按工资降序排列

  SELECT * FROM EMPLOYEES ORDER BY SALARY DESC;

21.SELECT EMPLOYEE_ID FROM EMPLOYEES ORDER BY 8 ASC 为什么会报错

  因为只查EMPLOYEE_ID 没有第八列

22.ORDER BY 后面跟数字

  SELECT EMPLOYEE_ID FROM EMPLOYEES ORDER BY 1 DESC

23.多列排序

  SELECT * FROM EMPLOYEES ORDER BY MANAGER_ID DESC,SALARY DESC;

24.ORDER BY跟数字 根据结果集的第几列排序

25.ORDER BY跟列名 根据列表里的该列排序

26.upper函数 lower函数

  SELECT UPPER(FIRST_NAME),LOWER(FIRST_NAME),FIRST_NAME FROM EMPLOYEES;

27.initcap函数

  SELECT INITCAP('COURSE Course cOURSE course) from dual;

大小写转换函数不能有逗号

28.CONCAT函数 字符连接函数 只能有两个参数

  SELECT CONCAT('World','haha')from dual;

SUBSTR函数 第一个数字是字符串的第几位开始输出

  SELECT SUBSTR('HelloWorld',2,5)from dual;

第二个数字是字符串需要输出几个

29.LENGTH函数 统计字符串长度

  SELECT LENGTH('HELLO   ,,WORLD)FROM DUAL; 返回值15

30.instr函数  第一列 给出的字符串

第二个 要寻找的字符

第三列 从字符串第几位开始寻找

第四列 第几次出现在字符串的绝对位置

  SELECT INSTR('HELLOWORLD','W',2,1)FROM DUAL;返回6

   SELECT INSTR('HELLOWORLD','L',1,1)FROM DUAL;返回3

SELECT INSTR('HELLOWORLD','L',2,2)FROM DUAL;返回4

SELECT INSTR('HELLOWORLD','L',4,1)FROM DUAL;返回4

31.LPAD函数 LPAD(SALARY,10,'*')在左边补补*补到10个字符

RPAD函数 LPAD(SALARY,10,'*')在右边补补*补到10个字符

  SELECT LPAD(SALARY,10,'*') FROM EMPLOYEES;

   SELECT RPAD(SALARY,10,'$') FROM EMPLOYEES;

32.REPLACE函数 'JACK and JUE','J','BL'把所有的J换成BL

  SELECT REPLACE('JACK and JUE','J','BL')FROM DUAL;

33.TRIM函数 TRIM('l'from 'HelloWorld')首尾都删l 删到不是l为止就停了

  SELECT TRIM('H'from 'HelloWorld')FROM DUAL

  SELECT TRIM('H'from 'HHelloWorldH')FROM DUAL

  SELECT TRIM('H'from 'HHHelloWorldHH')FROM DUAL

34.显示EMPLOYEES表中收入超过12000的雇员的名字和薪水

  SELECT FIRST_NAME,SALARY FROM EMPLOYEES WHERE SALARY>12000;

35.显示EMPLOYEES表中雇员号为176的雇员的名字和部门号

  SELECT FIRST_NAME,DEPARTMENT_ID FROM EMPLOYEES WHERE EMPLOYEE_ID=176;

36.显示EMPLOYEES表中薪水不在5000到12000之间的雇员名字和薪水

  SELECT FIRST_NAME,DEPARTMENT_ID FROM EMPLOYEES WHERE SALARY<5000 OR SALARY>12000;

37.显示EMPLOYEES表中受雇日期在2005年2月20日到2005年5月1日之间的雇员的名字、岗位

  SELECT FIRST_NAME,JOB_ID FROM EMPLOYEES WHERE HIRE_DATE BETWEEN TO_DATE('2005-02-20','yyyy-mm-dd') AND TO_DATE('2005-05-01','yyyy-mm-dd');

38.显示EMPLOYEES表中所有在部门20和50中的雇员的名字和部门号,并以名字按字母顺序排序

  SELECT FIRST_NAME,DEPARTMENT_ID FROM EMPLOYEES WHERE DEPARTMENT_ID IN (20,50) ORDER BY FIRST_NAME;

39.显示EMPLOYEES表中收入在5000和12000之间,并且在部门20或50的员工名字和薪水,将列标题分别显示为EMPLOYEE和MONTHLY SALARY

  SELECT FIRST_NAME AS "EMPLOYEE" , SALARY AS "MONTHLY SALARY" FROM EMPLOYEES WHERE (SALARY BETWEEN 5000 AND 12000)AND (DEPARTMENT_ID IN (20,50));

40.ROUND函数:四舍五入到指定的十进制

TRUNC函数:截断到指定的十进制值

MOD:返回余数

  SELECT ROUND(123.45678,3) FROM DUAL;四舍五入,截止到小数点后3位

  SELECT TRUNC(123.45678,-1) FROM DUAL;不四舍五入,截止到小数点前一位

41.SYSDATE返回当前日期 SELECT SYSDATE-1 AS "昨天",SYSDATE AS "今天",SYSDATE+1 AS "明天" FROM DUAL;

42.SELECT ENAME,SYSDATE-HIRE_DATE||'天' AS "入职天数",(SYSDATE-HIRE_DATE)/365||'年' AS "入职年数" FROM EMP; SYSDATE 减去 HIRE_DATE等于入职天数

43.MONTHS_BETWEEN 两个日期相差的月数

ADD_MONTH 向指定日期加上若干月数

NEXT_DAY 指定日期的下一个日期

LAST_DAY 本月的最后一天

44.SELECT MONTHS_BETWEEN(TO_DATE('2016-12-20','yyyy-mm-dd'),TO_DATE('2018-03-28','yyyy-mm-dd')) FROM DUAL;

用TO_DATE函数进行字符串与日期格式的转换来求出月份多少

  1. SELECT

SYSDATE,NEXT_DAY(SYSDATE,1),NEXT_DAY(SYSDATE,2),NEXT_DAY(SYSDATE,3),NEXT_DAY(SYSDATE,4),NEXT_DAY(SYSDATE,5),NEXT_DAY(SYSDATE,6),NEXT_DAY(SYSDATE,7),

NEXT_DAY函数 后面的数字是显示下一个周几 按日一二三四五六排1234567

46.显示EMPLOYEES表中每一个在2005年受雇的雇员的名字和受雇日期

  SELECT FIRST_NAME,HIRE_DATE FROM EMPLOYEES WHERE HIRE_DATE BETWEEN TO_DATE('2005-01-01 00:00:00','yyyy-mm-dd hh24:mi:ss') AND TO_DATE('2005-12-31 00:00:00','yyyy-mm-dd hh24:mi:ss');

显示EMPLOYEES表中所有没有主管经理的雇员名字和工作岗位

  SELECT FIRST_NAME,JOB_ID FROM EMPLOYEES WHERE MANAGER_ID IS NULL;

显示EMPLOYEES表中所有有佣金的雇员的名字、薪水和佣金,以薪水和佣金的降序排列数据

  SELECT FIRST_NAME,SALARY,COMMISSION_PCT FROM EMPLOYEES WHERE COMMISSION_PCT IS NOT NULL ORDER BY SALARY DESC,COMMISSION_PCT DESC;

显示EMPLOYEES表中所有名字第三个字母是a的雇员的名字

  SELECT FIRST_NAME WHERE FIRST_NAME LIKE '__a%';

显示EMPLOYEES表中所有名字中有一个a和一个e的雇员的名字

  SELECT FIRST_NAME WHERE FIRST_NAME LIKE '%a%' OR FIRST_NAME LIKE '%e%';

显示EMPLOYEES表中所有工作是SA_REP或者ST_CLERK,并且薪水不等于2500、3500或7000的雇员的名字、工作和薪水

  SELECT FIRST_NAME,JOB_ID,SALARY FROM EMPLOYEES WHERE (JOB_ID = 'ST_CLERK' OR JOB_ID = 'SA_REP') AND SALARY NOT IN (2500,3500,7000);

47.TO_CHAR,TO_NUMBER,TO_DATE 使NUMBER CHAR DATE三种格式相互转换

TO_CHAR 函数 常用的几种格式

9代表一个数字 0强制显示0 $设置一个浮动的美元符号 . 代表小数点 ,在千分位加逗号

48.NVL函数 NVL(com,0)若com不为空,则输出com;若com为空,则输出0

49.NVL2函数 NVL(e1,e2,e3) 若e1不为空,输出e2;若e1为空,则输出e3

SELECT NVL2(COMMISSION,(SALARY+SALARY*COMMISSION)*12,SALARY*12) FROM EMPLOYEES ;

50.NULLIF函数 NULLIF(X1,X2)当X1=X2返回空值;当X1!=X2返回X1

51.CASE表达式

SELECT  LAST_NAME ,JOB_ID,SALARY,

    CASE JOB_ID WHEN ‘IT_PROG’ THEN 1.10*SALARY

           WHEN ‘ST_CLERK’ THEN 1.15*SALARY

            WHEN ‘SA_REP’ THEN 1.20*SALARY

           ELSE         SALARY

           END

           “REVISED_SALARY”

FROM EMPLOYEES;

52.DECODE函数

SELECT  LAST_NAME ,JOB_ID,SALARY,

    DECODE(JOB_ID  ‘IT_PROG’ ,1.10*SALARY,

            ‘ST_CLERK’ ,1.15*SALARY,

             ‘SA_REP’ ,1.20*SALARY,

                    SALARY)

            “REVISED_SALARY”

FROM EMPLOYEES;

53显示雇员的LAST_NAME和COMMISSION比率,如果雇员没有佣金,则显示为“NO COMMISSION”,列标签为COMM

SELECT LAST_NAME,NVL(TO_CHAR(COMMISSION_PCT),'NO COMMISSION') AS "COMM" FROM EMPLOYEES;

54.用DECODE函数,按照下面的数据显示所有雇员基于JOB_ID的类别

SELECT LAST_NAME,JOB_ID,DECODE(JOB_ID,'AD_PRES','A','ST_MAN','B','IT_PROG','C','SA_REP','D','ST_CLERK','E','0') AS "GRADE" FROM EMPLOYEES;

55.用CASE表达式,重写上述问题的答案

SELECT LAST_NAME,JOB_ID ,CASE JOB_ID WHEN 'AD_PRES' THEN 'A'  WHEN 'ST_MAN' THEN 'B' WHEN 'IT_PROG' THEN 'C' WHEN 'SA_REP' THEN 'D' WHEN 'ST_CLERK' THEN 'E' ELSE '0' END AS "GRADE" FROM EMPLOYEES;

56.分组函数作用于一组数据,并对一组数据返回一个值

AVG 平均值 COUNT 统计值 MAX最大值 MIN最小值 SUM总和

可以对数值型数据使用AVG和SUM函数

可以对数值型、字符型和日期型使用MIN和MAX函数

SELECT COUNT(*) 返回表中总行数

SELECT COUNT(*) FROM EMPLOYEES;返回107行

SELECT COUNT(expr)返回非空值的expr的行数

SELECT COUNT(LAST_NAME) FROM EMPLOYEES;返回107 行

SELECT COUNT(COMMISSION_PCT) FROM EMPLOYEES;返回35行

SELECT COUNT(DISTINCT espr)返回去掉重复行的行数

SELECT COUNT(DISTINCT LAST_NAME) FROM EMPLOYEES;返回102行

组函数忽略空值

SELECT AVG(COMMISSION_PCT) FROM EMPLOYEES;返回0.2,这个把空值忽略掉了,结果结果变大了

NVL函数使组函数无法忽略空值

SELECT AVG(NYL(COMMISSION_PCT,0)) FROM EMPLOYEES;返回0.07,这个把空值算0,结果是对的

57.GROUP BY 聚合函数 不能使用列别名。SELECT后面有限制

SELECT COMMISSION_PCT,COUNT(COMMISSION_PCT),ROUND(AVG(SALARY),0) FROM EMPLOYEES GROUP BY COMMISSION_PCT;

58.多列分组,把两列进行分组,在GROUP BY字句中包含多个列

比如department_id 和 job_id都相同的 进行分组

SELECT DEPARTMENT_ID,JOB_ID,SUM(SALARY)

FROM EMPLOYEES

WHERE DEPARTMENT_ID>40

GROUP BY DEPARTMENT_ID,JOB_ID

ORDER BY DEPARTMENT_ID;

59.查询哪个部门的最高薪水>10000

SELECT * FROM(SELECT DEPARTMENT_ID,MAX(SALARY) AS "MAXSALARY" FROM EMPLOYEES GROUP BY DEPARTMENT_ID ) WHERE MAXSALARY>10000;

使用HAVING字句过滤分组:1.行已经被分组2.使用了组函数3.满足having字句中条件的分组将被显示

SELECT DEPARTMENT_ID,MAX(SALARY)FROM EMPLOYEES GROUP BY DEPARTMENT_ID HAVING MAX(SALARY)>10000;

HAVING字句 GROUP BY字句不能使用别名

SQL部分常用指令整理的更多相关文章

  1. sql*plus常用指令介紹

    sql*plus常用指令介紹 1.用set指令來設定SQL*Plus的環境參數值 格式: Set 環境參數名 環境參數值 ex:set feedback on set feedback 8.用show ...

  2. Linux常用指令整理

    Linux常用命令整理 快捷键 [Tab] [Tab] 接在一串指令的第一个字的后面,则为"命令补全": [Tab] 接在一串指令的第二个字以后时,则为"文件补齐&quo ...

  3. git常用指令整理

    git常用指令一览表 GIT指令 说明 git add . 将全部文件的内容加到Git索引以便执行commit. 这个指令不会检查文件夹中是否有文件被删除. 要注意的是,只有执行" git ...

  4. SQL SERVER 常用知识整理

    以前写了一些关于sql的文章,包括一些转载的,这里做下整理,方便需要时候使用 一.基础运用 SQL 数据结构操作语句 SQL 时间处理 SQL 常见函数使用 CASE WHEN THEN 小结 二.优 ...

  5. Linux 常用指令整理

    1. 查看端口占用情况 netstat -tunlp 2.压缩文件 文件夹 tar -cf 文件名.tar 文件夹 gzip 文件名.tar 文件 tar 文件名 文件1 文件2 ... gzip t ...

  6. Angular CLI ng常用指令整理

    一.组件创建 ng generate component heroes 二.运行项目 ng serve --open //--open 立即打开 三.创建指令 ng g directive my-ne ...

  7. Git常用指令整理(Git Cheat Sheet)

    [Toc] 1. 创建 复制一个已创建的仓库:git clone ssh://user@domain.com/repo.git 创建一个新的本地仓库:git init 2. 本地修改 显示工作路径下已 ...

  8. linux一些常用指令整理

    set number:设置行号 set list:区分tab和空格 按w:一个字一个字跳转 按b:一个字一个字回跳 shift+6:行首 shift+4:行尾 ctrl+v:选中块,再按shift+i ...

  9. vim常用指令整理小结

    启动Vim后,默认是在 Normal 模式下,但是我们有时不知道是在编辑模式还是normal模式,按ESC键就可以返回normal模式.因为所有的命令都需要在Normal模式下使用,所以建议多按几下E ...

随机推荐

  1. IDE-Android Studio -FAQ-使用习惯(不断更新 欢迎留言)

    摘要: 从ecplise工具切换到android studio后遇到了很多问题,起初亦非常痛苦,城墙内外阅博无数才得以解决.所以把当时遇到的问题记录下来,方便后来人学习. 另如果有遇到未纪录的问题欢迎 ...

  2. Python之socketserver模块和验证客户端链接的合法性

    验证客户端链接的合法性 分布式系统中实现一个简单的客户端链接认证功能 #_*_coding:utf-8_*_ from socket import * import hmac,os secret_ke ...

  3. JavaScript(js)/上

    JavaScript(js) ECMA-----定义的基础语法 DOM------document  object  model BOM------Browser  object  model Jav ...

  4. Docker:云栖社区开源论题及Spark开源论题

    https://yq.aliyun.com/topic/78?spm=5176.8290451.656547.7.rMYhAF https://yq.aliyun.com/activity/155?u ...

  5. ansible批量加用户

    ansible批量加用户 1.生成密码 pip install passlib python -c "from passlib.hash import sha512_crypt; print ...

  6. ecshop PC版本智能跳转到对应手机版页面

    以下适用于PC跳转到ectouch手机版的写法.其他手机端的方法类似. 修改文件 includes/lib_main.php 增加以下 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ...

  7. jacascript 事件流

    前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! 事件流 当浏览器发展到第四代时(IE4及Netscape4),浏览器开发团队遇到了一个很有意思的问题:页面 ...

  8. Qt 的一些浅知识点

    1 Qt 官网下载地址 http://download.qt.io/ 2 必须得有pro文件么 不是必须的. pro 文件是个中间文件,通过 qmake 程序能将 pro 文件转换成其它平台的项目文件 ...

  9. 确保 PHP 应用程序的安全 -- 不能违反的四条安全规则

    规则 1:绝不要信任外部数据或输入 关于 Web 应用程序安全性,必须认识到的第一件事是不应该信任外部数据.外部数据(outside data) 包括不是由程序员在 PHP 代码中直接输入的任何数据. ...

  10. css 宽高自适应的div 元素 如何居中 垂直居中

    在我们 编写css 样式的时候经常会遇见一个问题 那就是一个 宽高未知的元素 要让他 垂直居中如何实现这个呢 下面是我常用的两种方法 上代码 下面的是 结构代码 <div class=" ...