Oracle SQL用法

原创 2004年09月04日 13:37:00

这个是对于oracle数据库的sql基本语句,
SQL plus执行通过的
------------------------------------------------------------------

select empno, to_char(sal,'999,999.99') sal from emp;
select distinct deptno from emp;
select empno,ename,sal*0.5 from emp where deptno=10;
select empno||''||ename,nvl(sal,0)+nvl(comm,0) from emp;
select empno,ename,job,sal from emp where empno=&empno;
select sysdate,user,uid,rowid,rownum from emp;
[sysdate,user,uid,rowid,rownum为伪列]
select empno,ename,comm from emp where comm=null;
[comm is null];
select empno,ename,nvl(comm,"0") from emp where comm is null;
select deptno,dname from dept where deptno in(30,40);
select deptno,dname,loc from dept where loc not in('NEW YORK','CHICAGO');
select deptno,ename,sal from emp where deptno=10 or deptno=20 and sal>3000;
[列别名]
select e.ename EMPLOYEE,e.sal*1.15 NEW_SAl from emp e where e.deptno=10;
[多表连接]
select d.dname,e.ename,e.sal,e.comm from emp e,dept d where d.deptno=e.deptno order by d.deptno;
[使用子查询]
 select ename from emp where deptno=(select deptno from dept where dname='SALES');
[查询别名]
select e.ename,d.dname,e.deptno||'=='||d.deptno from emp e,
(select deptno,dname from dept where loc='NEW YORK') d
where e.deptno=d.deptno
order by d.deptno;
[union:联合]
select ename,sal,comm from emp
union
select 'TOTAL',sum(sal),sum(comm) from emp order by sal

ENAME            SAL      COMM
---------- --------- ---------
SMITH            800
JAMES            950
ADAMS           1100
SCOTT           3000
KING            5000
TOTAL          29025      2200
------------------------------
[intersect:相交]
select ename,sal,comm from emp where sal>1300
INTERSECT
select ename,sal,comm from emp where comm is not null
===select ename,sal,comm from emp where sal>1300 and comm is not null

ENAME            SAL      COMM
---------- --------- ---------
ALLEN           1600       300
TURNER          1500         0
------------------------------
[minus]
select ename,sal comm from emp where sal>1300
minus
select ename,sal comm from emp where sal>1500;
===select ename,sal,comm from emp where sal>1300 and not(sal>1500)
ENAME           COMM
---------- ---------
TURNER          1500
--------------------
select to_char(sysdate,'yyyy/mm/dd hh24:mi') sys_date from dual;
select to_date('2002/08/13','yyyy/mm/dd') from dual;
select to_number('12345',99999) from dual;
select empno,ename from emp where months_between(sysdate,hiredate)>=12;
    add_months(date,number)
    last_day(date)
    months_between(date1,date2)
    next_dat(date,day)
    round(date,format)
    trunc(date,format)
---------------------
数值函数
    abs(number)
    ceil(number)
    cos(number)
    ln(number)
    mod(n,m)
    round(number,decimal_digits)
    sign(number)
    sqrt(number)
    sin(number)
-------------------
字符函数   
    ascii(character)
    chr(number)
    concat(string1,string2) #||
    initcap(string)
    length(string)
    lower(string)   upper(string)
    substr(string,start[,length])
    replace(string,search_string,replace_string)
-------------------
other
     greatest(list of values)
     least(list of values)
     nvl(expression,replacement_value)
     AVG(expression)
     COUNT(expression)
     MAX(expression)
     MIN(expression)
     SUM(expression)
Welcome>select count(*),sum(sal),avg(sal),max(sal),min(sal) from emp;

 COUNT(*)  SUM(SAL)  AVG(SAL)  MAX(SAL)  MIN(SAL)
--------- --------- --------- --------- ---------
       14     29025 2073.2143      5000       800
---------------------------------------------------------------------------
[右连接:如下图,如果出现条件不符和的,以左边为主/e.deptno/,右边的/d.deptno/应该以空行还填补左边显示的内容]
select d.dname,e.ename from emp e,dept d where e.deptno=d.deptno(+) order by d.dname,e.ename;

  1  select d.dname D_Dname,e.ename E_Ename,d.deptno D_Deptno,e.deptno E_Deptno from emp e,dept d
  2* where e.deptno=d.deptno(+) order by d.dname,e.ename
Welcome>/

D_DNAME        E_ENAME     D_DEPTNO  E_DEPTNO
-------------- ---------- --------- ---------
ACCOUNTING     CLARK             10        10
ACCOUNTING     KING              10        10
ACCOUNTING     MILLER            10        10
RESEARCH       ADAMS             20        20
RESEARCH       FORD              20        20
RESEARCH       JONES             20        20
RESEARCH       SCOTT             20        20
RESEARCH       SMITH             20        20
SALES          ALLEN             30        30
SALES          BLAKE             30        30
SALES          JAMES             30        30
SALES          MARTIN            30        30
SALES          TURNER            30        30
SALES          WARD              30        30
---------------------------------------------

 

[左连接:如下图,如果出现条件不符和的,以右边为主/d.deptno/,左边的/e.deptno/应该以空行还填补右边显示的内容]
select d.dname D_Dname,e.ename E_Ename,d.deptno D_Deptno,e.deptno E_Deptno from emp e,dept d
where e.deptno(+)=d.deptno order by d.dname,e.ename

D_DNAME        E_ENAME     D_DEPTNO  E_DEPTNO
-------------- ---------- --------- ---------
ACCOUNTING     CLARK             10        10
ACCOUNTING     KING              10        10
ACCOUNTING     MILLER            10        10
OPERATIONS                       40
RESEARCH       ADAMS             20        20
RESEARCH       FORD              20        20
RESEARCH       JONES             20        20
RESEARCH       SCOTT             20        20
RESEARCH       SMITH             20        20
SALES          ALLEN             30        30
SALES          BLAKE             30        30
SALES          JAMES             30        30
SALES          MARTIN            30        30
SALES          TURNER            30        30
SALES          WARD              30        30
---------------------------------------------
[自连接:同一表表根据别名来访问]
select a.ename A_ename,b.ename B_ename,a.mgr A_mgr,b.empno B_empno
from emp a,emp b
where a.mgr=b.empno
order by b.ename,a.ename

A_ENAME    B_ENAME        A_MGR   B_EMPNO
---------- ---------- --------- ---------
ALLEN      BLAKE           7698      7698
JAMES      BLAKE           7698      7698
MARTIN     BLAKE           7698      7698
TURNER     BLAKE           7698      7698
WARD       BLAKE           7698      7698
MILLER     CLARK           7782      7782
SMITH      FORD            7902      7902
FORD       JONES           7566      7566
SCOTT      JONES           7566      7566
BLAKE      KING            7839      7839
CLARK      KING            7839      7839
JONES      KING            7839      7839
ADAMS      SCOTT           7788      7788
-----------------------------------------
select e.deptno,e.ename from emp e
where exists
(select 'x' from dept d where e.deptno=d.deptno
and d.loc='NEW YORK')
order by e.empno;

   DEPTNO ENAME
--------- ----------
       10 CLARK
       10 KING
       10 MILLER

 

26.Oracle数据库SQL开发之 SQLPlus使用——格式化列

26.Oracle数据库SQL开发之 SQLPlus使用——格式化列          COLUMN命令用于格式化列标题和列数据的显示格式。          语法如下: COL [UMN] { co...
  • notbaron
  • notbaron
  • 2015-11-08 22:29:48
  • 30844

27.Oracle数据库SQL开发之 SQLPlus使用——设置页面、行大小

27.Oracle数据库SQL开发之 SQLPlus使用——设置页面、行大小  欢迎转载,转载请标明出处: 1.  设置页面大小 一页中显示的行数可以使用SET PAGESIZE命令来设置。超过这么多...
  • notbaron
  • notbaron
  • 2015-11-08 22:30:42
  • 31570

sql中as的用法和Oracle中一些经典的sql语句

总结一些工作中用到或碰到的SQL语句,希望能与大家分享,同时也希望大家能提供更多的精妙SQL语句.....1、delete table1 from (select * from table2) as ...
  • langjian2012
  • langjian2012
  • 2014-09-26 10:32:13
  • 1386

ORACLE SQL IN关键字的用法

in后括号中的参数个数有限制,Oracle 9i 中个数不能超过256,Oracle 10g个数不能超过1000. 重点:参数个数,不是总长度。 如下SQL子查询返回结果大于1000个,也没关系,...
  • mycup163
  • mycup163
  • 2014-12-11 10:09:15
  • 1841

Oracle SQL:update更新语句总结

Oracle update SQL 语句总结: update 用于修改表中的数据
  • yihuiworld
  • yihuiworld
  • 2015-03-28 11:21:02
  • 39379

Oracle数据库执行Sql脚本的方法

Oracle数据库执行Sql文件的方法: 1、cmd 命令窗口:       sqlplus →连接数据库→sql>E:文件夹\*.sql   这样就能执行sql脚本了。     (PS:sql文件前...
  • u011595939
  • u011595939
  • 2016-11-16 17:56:16
  • 13428

sqlserver中的substring用法,oracle的substr,js中的substring

select substring(ziduan,1,6) 将会选择字段的前6个字符,比如说是200908 如果设置为0, 同样的执行select substring(zidua...
  • wangqiuchen_Study
  • wangqiuchen_Study
  • 2014-07-04 16:35:38
  • 1356

Oracle 尽量避免在SQL语句中使用 OR

-- Start 在SQL 语句中应该尽量避免使用OR,因为这样做会影响SQL 语句的性能。考虑下面的情况: CREATE TABLE EMPLOYEE ( NAME VARCHAR2...
  • shangboerds
  • shangboerds
  • 2015-06-19 14:01:44
  • 6766

Oracle SQL Developer 使用简要说明

Oracle SQL Developer 使用简要说明 Oracle SQL Developer 是免费的图形化数据库开发工具。使用 SQL Developer,可以浏览数据库对象、运行 SQL 语句...
  • jack2009win
  • jack2009win
  • 2013-08-18 23:19:44
  • 22265

oracle 非常完整的总结

原文:http://blog.csdn.net/bff1022/article/details/17462435# 目录(?)[+] Ⅰ.oracle itcast 本文档对应程序在mye...
  • hello_zhou
  • hello_zhou
  • 2016-08-24 22:30:19
  • 5378
收藏助手
不良信息举报
您举报文章:Oracle SQL用法
举报原因:
原因补充:

(最多只允许输入30个字)