Oracle一些查询的案例,(查询的优先级,Sql--plus函数,数字函数,日期时间函数)[详细版]
2011-04-16 16:21
645 查看
简单的条件查询 (查询的优先级,Sql--plus函数,数字函数,日期时间函数) SELECT *|{[DISTINCT] column|expression [alias],...} FROM table [WHERE condition(s)]; Condition(s)要使用到比较运算符常用的比较运算符如下: 操作符 含义 = 等于 > 大于 >= 大于等于 < 小于 <= 小于等于 <> 不等于 等效于!= 其它操作 And 逻辑运算 逻辑与 Or 逻辑运算 逻辑或 Not 逻辑运算 逻辑否 Between 起始值 and 结束值:使用 BETWEEN 运算来显示在一个区间内的值 包含(起始结束值) In: 使用 IN运算显示列表中的值。 In(,,,)相当于一个集合,只要出现集合中匹配的就显示 Like: l 使用 LIKE 运算选择类似的值 l 选择条件可以包含字符或数字: • % 代表零个或多个字符(任意个字符)。 • _ 代表一个字符。 Escape: 回避特殊符号的:使用转义符。例如:将[%]转为[/%]、[_]转为[/_],然后再加上[ESCAPE ‘/’] 即可 Null: 使用 IS (NOT) NULL 判断空值。 //查询部门号为10的员工信息 部门为整数类型 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno=10; //查询职位号为MANAGER的员工信息 岗位的类型为字符类型 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER'; //查询部门号为10并且员工的职位为MANAGER的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER' anddeptno=10; 注意: l 字符和日期要包含在单引号中。 l 字符大小写敏感,日期格式敏感。 l 默认的日期格式是 DD-MON-RR。 //查询部门号大于10的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno>10; //查询薪水大于等于3000的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=3000; //查询薪水不等于3000的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal<>3000; SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal !=3000; //查询薪水大于2000并且小于3000的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>2000 andsal<3000; //查询薪水大于等于2000并且小于等于3000的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal between 1600and 3000; //等效于 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=1600 andsal<=3000; //查询部门号位10,20的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno in(10,20); //注意:相当于如下操作: SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno =10 ordeptno=20; //查询员工名称以S开头的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like 'S%'; //查询员工名称以S结尾的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%S'; //查询员工名称第三个字符为N的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '__N%'; //查询员工名称中含有N的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%N%'; //查询员工名称中倒数第二个字符为%的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like'%/%_'escape'/'; //查询员工名称总含有%的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like'%/%%'escape'/'; //查询奖金为null的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is null; //查询奖金非null的员工信息 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is not null; 优先级表格: 优先级 1 算术运算 2 连接符 3 比较符 4 Is not null like not in 5 Not between 6 not 7 and 8 Or 备注:可以采用括号改变优先级 关系数据库-à层次关系---》网状的关系-à关系数据库-à对象关系。 子句: l 使用ORDER BY 子句排序 • ASC(ascend): 升序 • DESC(descend): 降序 l ORDERBY 子句在SELECT语句的结尾。 //查询员工信息按照部门的编号进行升序排列 默认的是 asc SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno; //查询员工信息按照部门的编号进行降序排列 使用desc SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno desc; //查询部门为20的员工信息并按照员工的编号进行升序排列 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno=20 order by empno asc; 备注:可以与条件语句结合使用但order by子句放在最后 //查询员工信息并按照员工的部门编号升序并且编号进行降序排列 SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno asc,empno desc; 备注:理解思路:首先查询员工信息按照部门的编号进行升序,然后每个部门中的员工按照员工的编号进行降序排列 总结: 整体语法如下: SELECT *|{[DISTINCT] column|expression [alias],...} FROM table [WHERE condition(s)] [ORDER BY {column, expr, alias} [ASC|DESC]]; 通过学习可以完成 使用where子句、between、like、in、null、not 、or、and等来过滤数据,也可以使用order by子句进行对查询结果排序数据。 Sql--plus函数: 字符串函数是oracle使用最广泛的一种函数. LOWER:小写 UPPER:大写 INITCAP:首字母大写 CONCAT:连接 SUBSTR:截取 (参数,开始,数目) LENGTH:返回字符串的长度 INSTR:(参数,字母) 返回字母出现的位置 LPAD:(参数,长度,在前补齐参数字母) | RPAD:(参数,长度,在后补齐参数字母) TRIM : REPLACE:(参数,参数[,参数]):第一个参数操作数,第二是要查找的字符,第三个是替换的字符,如果没有第三个就删除查找的字符。 //查询名称为scott的员工信息 (不区分大小写) SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where lower(ename)='scott'; SQL> selectempno,ename,job,mgr,hiredate,sal,comm,deptno from emp where upper(ename)='SCOTT'; //查询员工信息把员工名称与工作连接在一起 SQL> selectempno,concat(ename,job),mgr,hiredate,sal,comm,deptno from emp; //查询员工信息把员工名称与工作连接在一起 SQL> select empno,concat(ename||'iswork:',job),mgr,hiredate,sal,comm,deptno from emp; //查询员工名称中含有O字符的位置 SQL> selectempno,instr(ename,'O'),job,mgr,hiredate,sal,comm,deptno from emp; //查询员工名称中含有O字符的位置并且求出了员工名称字符长度 SQL> selectempno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from emp; //在查询上面结果中过滤出员工工作从第三字母开始为ERK员工信息 SQL> selectempno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from empwhere substr(job,3)='ERK'; 备注:当含有两个参数的时候,从开始位置直接到参数结束的结束为止 //在效果同上的同时指明了截取个数为3 SQL> selectempno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from empwhere substr(job,3,3)='ERK'; //查询员工信息 薪资是10位位数不够在左部分补*填充 SQL> selectempno,ename,job,mgr,hiredate,LPAD(sal,10,'*'),comm,deptno from emp; //查询员工信息 薪资是10位位数不够在右部分补*填充 SQL> selectempno,ename,job,mgr,hiredate,RPAD(sal,10,'*'),comm,deptno from emp; //查询员工信息 把员工名称中含有S字符去除掉 SQL> selectempno,TRIM('S' from ename),job,mgr,hiredate,10,comm,deptno from emp; 等效于: SQL> selectempno,TRIM( both 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp; //查询员工信息 把员工名称中前面有S字符去除掉 SQL> selectempno,TRIM( Leading 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp; //等效于 SQL> selectempno,LTRIM( ename,'S'),job,mgr,hiredate,10,comm,deptno from emp; //查询员工信息 把员工名称中后面有S字符去除掉 SQL> selectempno,TRIM( trailing 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp; 等效于: SQL> selectempno,RTRIM( ename,'S'),job,mgr,hiredate,10,comm,deptno from emp; 数字函数: ROUND: 四舍五入 ROUND(45.926, 2) 45.93 TRUNC: 截断 TRUNC(45.926, 2) 45.92 MOD: 求余 MOD(1600, 300) 100 ABS:绝对值 CEIL:返回大于或等于value的最小整数 FLOOR:返回小于或等于value的最大整数 SQRT :返回value的平方根 负数无意义。 //四舍五入 结果为46 SQL> select round(45.56) from dual; //绝对值 结果为45.56 SQL> select abs(-45.56) from dual; //大于等于最小整数 结果为-45 SQL> select ceil(-45.56) from dual; //小于等于最大整数 结果为-46 SQL> selectfloor(-45.56) from dual; //求余数 结果为300 SQL> selectmod(1800,500) from dual //截取的数的操作数是正数的情况下:只操作小数位 结果为1800.11 SQL> selecttrunc(1800.11111,2) from dual; //截取的数的操作数是负数的情况下:操作的是小数点之前的位,把操作位小数点之前的位数全部改写成0. 结果就是1000 SQL> selecttrunc(1899.11111,-3) from dual; 日期时间函数 Oracle 中的日期型数据实际含有两个值: 日期和时间。默认的日期格式是 DD-MON-RR.日期时间函数用来返回当前系统的日期和时间、以及对日期和时间类型的数据进行处理运算。 add_months(date,count);在指定的日期上增加count个月 last_day(date);返回日期date所在月的最后一天 months_between(date1,dates);返回date1到date2之间间隔多少个月 new_time(date,this’,’other’);将时间date从this时区转换成other时区 next_day(day,’day’);返回指定日期或最后一的第一个星期几的日期,这里day为星期几 sysdate();获取系统的当前日期 current_timestamp();获取当前的时间和日期值 round:日期的四舍五入 trunc 日期的截取 日期的数学运算: l 在日期上加上或减去一个数字结果仍为日期。 l 两个日期相减返回日期之间相差的天数。 l 可以用数字除24来向日期中加上或减去小时。 //获取系统的当前时间 显示的格式采用默认格式显示结果:07-4月-11 11.15.38.390000 上午 +08:00 SQL> selectcurrent_timestamp from dual; //获取系统的当前日期值 显示结果:2011-4-7 11 SQL> selectsysdate from dual; //为当前日期加上3个月 显示的结果:2011-7-7 11:18:36 selectadd_months(sysdate,3) from dual; //返回当前月的最后一天 显示的结果:2011-4-30 11:19:4 selectlast_day(sysdate) from dual; //返回两个日期之间的间隔月是几: 结果为:4 SQL> selectmonths_between(add_months(sysdate,4),sysdate) from dual; //从GMT时区转换成AST时区的日期结果 SQL> select new_time(sysdate,'GMT','AST')from dual; //返回下一个星期一的日期值 必须写成星期’几’ SQL> select next_day(sysdate,'星期一') from dual; 转换函数: 隐式转换:在运算过程中由系统自动完成的 显式转换:在运算过程中需要调用相应的转换函数实现。 to_char(date,’format’):按照指定的格式format把数字或日期类型的数据转换成字符串 格式: 必须包含在单引号中而且大小写敏感。 可以包含任意的有效的日期格式。 日期之间用逗号隔开。 //把当前日期转换成YYYY/MM/DD的格式 SQL> selectto_char(current_timestamp,'YYYY/MM/DD') from dual; //把当前日期转换成YYYY/MM/DDHH24/MI/SS AM的格式 SQL> selectto_char(current_timestamp,'YYYY/MM/DD HH24/MI/SS AM') from dual; //DD “of” MONTH SQL> selectto_char(current_timestamp,'YYYY DD "of" MONTH HH/MI/SS AM') from dual; //把当数字按照$99,999这种方式返回字符串 并且操作数的位数不能够大于5(即$后边的位数)位,否则话结果会是######## SQL> selectto_char(11111,'$99,999') from dual; to_number(char);把包含了数字格式的字符串转换成数字数据 to_date(string,’format’);按照指定格式的format把字符串转换成日期数据,如果省略了foramt格式,那么就采用默认的日期格式(DD-MON-YY); //把当前字符串转换成日期 SQL> selectto_date('2011-02-08','YYYY-MM-DD') from dual; //求出两个日期之间相差的天数 SQL> selectto_date('2011-07-15','YYYY-MM-DD')-to_date('2011-02-08','YYYY-MM-DD') fromdual; //求出两个日期之间相差的周次 SQL> select(to_date('2011-07-15','YYYY-MM-DD')-to_date('2011-02-08','YYYY-MM-DD'))/7 fromdual; //对周次进行向上取整 SQL> selectceil((to_date('2011-07-15','YYYY-MM-DD')-to_date('2011-02-08','YYYY-MM-DD'))/7)from dual; chartorowid(char);把字符串转换成rowid类型 rowidtochar(x);把rowid类型转换成字符类型数据 通用函数 这些函数适用于任何数据类型,同时也适用于空值: NVL (expr1, expr2) NVL2 (expr1, expr2, expr3) NULLIF (expr1, expr2) COALESCE (expr1, expr2, ..., exprn) nvl() 将空值转换成一个已知的值: l 可以使用的数据类型有日期、字符、数字。 l 函数的一般形式: • NVL(commission_pct,0) • NVL(hire_date,'01-JAN-97') • NVL(job_id,'No Job Yet') //将comm为null替换成0 SQL> select empno,ename,job,mgr,hiredate,sal,nvl(comm,0),deptnofrom emp; //在上面的基础上将日期为空替换成给定的日期 SQL>select empno,ename,job,mgr,nvl(hiredate,to_date('2011-1-10','YYYY-MM-DD')),sal,nvl(comm,0),deptnofrom emp; //在上面的基础上将job为空替换成redarmy SQL> selectempno,ename,nvl(job,'redarmy'),mgr,nvl(hiredate,to_date('2011-1-10','YYYY-MM-DD')),sal,nvl(comm,0),deptnofrom emp; //计算出员工在该月的工资=(薪资+奖金) SQL> selectempno,ename,job,mgr,hiredate,(nvl(sal,0)+nvl(comm,0)) as "工资",deptnofrom emp; NVL2 (expr1, expr2, expr3) : expr1不为NULL,返回expr2;为NULL,返回expr3。 相当于:expr1!=null?exrp2:expr3; //计算员工的工资 SQL> selectempno,ename,job,mgr,hiredate,nvl2(comm,sal+comm,sal) as "工资",deptnofrom emp; NULLIF (expr1, expr2) : 相等返回NULL,不等返回expr1 //注意观察理解 SQL> select enameas "expr1",job as "expr2",nullif(length(ename),length(job))from emp; l COALESCE与 NVL 相比的优点在于COALESCE 可以同时处理交替的多个值。 l 如果第一个表达式为空,则返回下一个表达式,对其他的参数进行COALESCE 。 SQL> selectempno,ename,job,mgr,hiredate,coalesce(comm,sal,10000) as "salll",deptno from emp; l 重点理解:单行函数可以嵌套。嵌套函数的执行顺序是由内到外。 条件表达式:IF-THEN-ELSE 逻辑 CASE expr WHEN comparison_expr1 THEN return_expr1 [WHENcomparison_expr2 THEN return_expr2 WHENcomparison_exprn THEN return_exprn ELSE else_expr] END DECODE(col|expression, search1, result1 [, search2,result2,...,] [, default]) //为职位是Manager的员工 发放5000元的奖金 SQL> selectename,job,case job when 'MANAGER' then nvl(sal,0)+5000 end as"工资" from emp; //员工的工资 SQL> select ename,job, 2 casejob when 'MANAGER' then nvl(sal,0)+5000+nvl(comm,0) 3 elsenvl(sal,0)+nvl(comm,0) 4 end 5 fromemp; //改写成 decode的写法 SQL> selectename,job 2 ,decode(job,'MANAGER', nvl(sal,0)+5000+nvl(comm,0), 3 'CLERK',nvl(sal,0)+nvl(comm,0)+200, 4 nvl(sal,0)+nvl(comm,0)) as "工资" 5 fromemp;
相关文章推荐
- oracle心得1--oracle简介@基本sql语句@条件查询@排序数据理论与案例
- oracle sql查询使用函数
- oracle的一些sql查询例子,(子查询、分组查询、求和、求平均数等等)都囊括到了。(2)
- SQL 10 函数 3 日期时间函数 - 4 日期增减(Oracle)
- Oracle中简单查询、限定查询、数据排序SQL语句范例和详细注解
- oracle的一些sql查询
- Oracle dual表 sql语句的一些函数(下)
- Oracle简单查询,常用函数(SQL语句集)
- 关于oracle的函数,存储过程,触发器,序列,视图,左右连接一些的应用 带案例
- Oracle经典sql语句总结@sql-plus重点函数串讲与sql语句案例@中文排序详讲).doc
- Oracle Lesson 2 SQL 查询和 SQL 函数(上)
- Oracle常用sql语句(二)之组函数、多表查询
- oracle的一些常用的查询的sql语句
- [转] Oracle sql 查询突然变慢 -- 案例分析
- Oracle模糊查询之(3.3从使用函数和sql语法角度来提高模糊查询效率 三)使用Oracle的instr函数与索引配合提高模糊查询的效率
- Oracle 中查询字段详细信息的sql 语句
- Oracle经典sql语句总结@sql-plus重点函数串讲与sql语句案例@中文排序详讲).doc
- ORACLE SQL总结一:集合函数和多表查询
- Oracle常用sql语句(二)之组函数、多表查询
- 笔记:Oracle SQL 高级查询简介 (2) 分析函数