码迷,mamicode.com
首页 > 数据库 > 详细

Oracle学习(8):处理数据

时间:2015-06-01 14:52:04      阅读:208      评论:0      收藏:0      [点我收藏+]

标签:oracle   学习笔记   数据库   

处理数据


*******************************************************************************************

一个decode语句练习

技术分享


SQL> select count(*) Total,

  2         sum(decode(to_char(hiredate,‘yyyy‘),‘1980‘,1,0)) "1980",
  3         sum(decode(to_char(hiredate,‘yyyy‘),‘1981‘,1,0)) "1981",
  4         sum(decode(to_char(hiredate,‘yyyy‘),‘1982‘,1,0)) "1982",
  5         sum(decode(to_char(hiredate,‘yyyy‘),‘1987‘,1,0)) "1987"
  6  from emp;


     TOTAL       1980       1981       1982       1987                          
---------- ---------- ---------- ---------- ----------                          
        14          1         10          1          2                          

*******************************************************************************************




SQL语言的类型

SQL> /*
SQL> SQL语言的类型
SQL> 1. DML(Data Manipulation Language 数据操作语言):insert delete update select
SQL> 2. DDL(Data Definition Language 数据定义语言): create table,create view,create user
SQL>                                                alter table,alter user
SQL>                                                drop table,drop user
SQL> 3. DCL(Data Control Language 数据控制语言): commit rollback truncate
SQL> */
SQL> host cls


插入 insert语句


语法

INSERT INTO  table[(column [,column...])]

VALUES  (value[, value...]);


使用INSERT 语句向表中插入数据。
使用这种语法一次只能向表中插入一条数据。

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -- - - - - - - - - - - -

INSERT INTO departments(department_id, department_name,

                        manager_id, location_id)

VALUES      (70, ‘PublicRelations‘, 100, 1700);


为每一列添加一个新值。
按列的默认顺序列出各个列的值。
在INSERT 子句中随意列出列名和他们的值。
字符和日期型数据应包含在单引号


- - - - - - - - - - - -- - - - - - - - - - - -- - - - - - - - - - - -- - - - - - - - - - - -- - - - - - - - - - - -- - - - - - - - - - - -



SQL> --插入 insert
SQL> desc emp
 名称                                      是否为空? 类型
 ----------------------------------------- -------- ----------------------------
 EMPNO                                     NOT NULL NUMBER(4)
 ENAME                                              VARCHAR2(10)
 JOB                                                VARCHAR2(9)
 MGR                                                NUMBER(4)
 HIREDATE                                           DATE
 SAL                                                NUMBER(7,2)
 COMM                                               NUMBER(7,2)
 DEPTNO                                             NUMBER(2)


SQL> insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno)
  2  values (1001,‘Tom‘,‘CLERK‘,7839,sysdate,2000,100,10);


已创建 1 行。


隐式插入空值 显式插入空值

?隐式方式:在列名表中省略该列的值。
?显式方式:在VALUES 子句中指定空值。


SQL> --隐式插入空值 显式插入空值


SQL> insert into emp(empno,ename,sal,deptno) values(1002,‘Mary‘,2000,10);

SQL> insert into emp(empno,ename,sal,deptno) values(1003,‘Mary‘,null,10);




地址符的应用


SQL> --地址符 &

lSQL 语句中使用& 变量指定列值。
l& 变量放在VALUES子句中。

SQL> insert into emp(empno,ename,sal,deptno)
  2  values(&empno,&ename,&sal,&deptno);
输入 empno 的值:  1004
输入 ename 的值:  ‘Mike‘
输入 sal 的值:  2000
输入 deptno 的值:  10
原值    2: values(&empno,&ename,&sal,&deptno)
新值    2: values(1004,‘Mike‘,2000,10)


已创建 1 行。


SQL> /
输入 empno 的值:  1005
输入 ename 的值:  ‘aaa‘
输入 sal 的值:  3000
输入 deptno 的值:  20
原值    2: values(&empno,&ename,&sal,&deptno)
新值    2: values(1005,‘aaa‘,3000,20)


已创建 1 行。

给&xxx加引号之后,在后面赋值可不需要加引号

SQL> insert into emp(empno,ename,sal,deptno) values(&empno,‘&ename‘,&sal,&deptno);

输入 empno 的值:  1006
输入 ename 的值:  Tomaa
输入 sal 的值:  1500
输入 deptno 的值:  10
原值    1: insert into emp(empno,ename,sal,deptno) values(&empno,‘&ename‘,&sal,&deptno)
新值    1: insert into emp(empno,ename,sal,deptno) values(1006,‘Tomaa‘,1500,10)


已创建 1 行。


SQL> host cls


&可用于语句的任何地方:

SQL> select empno,ename,&unknown
  2  from emp;
输入 unknown 的值:  sal
原值    1: select empno,ename,&unknown
新值    1: select empno,ename,sal


     EMPNO ENAME             SAL                                                
---------- ---------- ----------                                                
      7369 SMITH             800                                                
      7499 ALLEN            1600                                                
      7521 WARD             1250                                                
      7566 JONES            2975                                                
      7654 MARTIN           1250                                                
      7698 BLAKE            2850                                                
      7782 CLARK            2450                                                
      7788 SCOTT            3000                                                
      7839 KING             5000                                                
      7844 TURNER           1500                                                
      7876 ADAMS            1100                                                


     EMPNO ENAME             SAL                                                
---------- ---------- ----------                                                
      7900 JAMES             950                                                
      7902 FORD             3000                                                
      7934 MILLER           1300                                                
      1001 Tom              2000                                                
      1002 Mary             2000                                                
      1003 Mary                                                                 
      1004 Mike             2000                                                
      1005 aaa              3000                                                
      1006 Tomaa            1500                                                


已选择20行。


SQL> /
输入 unknown 的值:  job
原值    1: select empno,ename,&unknown
新值    1: select empno,ename,job


     EMPNO ENAME      JOB                                                       
---------- ---------- ---------                                                 
      7369 SMITH      CLERK                                                     
      7499 ALLEN      SALESMAN                                                  
      7521 WARD       SALESMAN                                                  
      7566 JONES      MANAGER                                                   
      7654 MARTIN     SALESMAN                                                  
      7698 BLAKE      MANAGER                                                   
      7782 CLARK      MANAGER                                                   
      7788 SCOTT      ANALYST                                                   
      7839 KING       PRESIDENT                                                 
      7844 TURNER     SALESMAN                                                  
      7876 ADAMS      CLERK                                                     


     EMPNO ENAME      JOB                                                       
---------- ---------- ---------                                                 
      7900 JAMES      CLERK                                                     
      7902 FORD       ANALYST                                                   
      7934 MILLER     CLERK                                                     
      1001 Tom        CLERK                                                     
      1002 Mary                                                                 
      1003 Mary                                                                 
      1004 Mike                                                                 
      1005 aaa                                                                  
      1006 Tomaa                                                                


已选择20行。


SQL> select *
  2  from &t;
输入 t 的值:  dept
原值    2: from &t
新值    2: from dept


    DEPTNO DNAME          LOC                                                   
---------- -------------- -------------                                         
        10 ACCOUNTING     NEW YORK                                              
        20 RESEARCH       DALLAS                                                
        30 SALES          CHICAGO                                               
        40 OPERATIONS     BOSTON                                                


SQL> /
输入 t 的值:  salgrade
原值    2: from &t
新值    2: from salgrade


     GRADE      LOSAL      HISAL                                                
---------- ---------- ----------                                                
         1        700       1200                                                
         2       1201       1400                                                
         3       1401       2000                                                
         4       2001       3000                                                
         5       3001       9999                                                


SQL> host cls




从其它表中拷贝数据


·在INSERT语句中加入子查询。 

    INSERT INTO sales_reps(id, name, salary, commission_pct)

     SELECT employee_id, last_name, salary, commission_pct

     FROM   employees

     WHERE  job_id LIKE ‘%REP%‘;


·不必书写 VALUES 子句。
·子查询中的值列表应与INSERT 子句中的列名对应



SQL> --一次插入(拷贝)多条数据?  
SQL> create table  emp10 as select * from emp where 1=2;    (因为1=2不成立,所以不会拷贝任何数据,但是会将表结构拷贝过来!


表已创建。


SQL> desc emp10
 名称                                      是否为空? 类型
 ----------------------------------------- -------- ----------------------------
 EMPNO                                              NUMBER(4)
 ENAME                                              VARCHAR2(10)
 JOB                                                VARCHAR2(9)
 MGR                                                NUMBER(4)
 HIREDATE                                           DATE
 SAL                                                NUMBER(7,2)
 COMM                                               NUMBER(7,2)
 DEPTNO                                             NUMBER(2)


SQL> insert into emp10
  2  select * from emp where deptno=10;


已创建3行。


SQL> select * from emp10;


     EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM 
---------- ---------- --------- ---------- -------------- ---------- ---------- 
    DEPTNO                                                                      
----------                                                                      
      7782 CLARK      MANAGER         7839 09-6月 -81           2450            
        10                                                                      
                                                                                
      7839 KING       PRESIDENT            17-11月-81           5000            
        10                                                                      
                                                                                
      7934 MILLER     CLERK           7782 23-1月 -82           1300            
        10                                                                      
                                                                                


SQL> --在插入中使用子查询
SQL> create table  emp20 as select * from emp where deptno=20;


表已创建。


SQL> select * from emp20;


     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO                                                                 
---------- ---------- --------- ---------- -------------- ----- ---------- ----------                                                                 
      7369 SMITH      CLERK           7902 17-12月-80       800                    20                                                                 
      7566 JONES      MANAGER         7839 02-4月 -81      2975                    20                                                                 
      7788 SCOTT      ANALYST         7566 13-7月 -87      3000                    20                                                                 
      7876 ADAMS      CLERK           7788 13-7月 -87      1100                    20                                                                 
      7902 FORD       ANALYST         7566 03-12月-81      3000                    20                                                                 




更新数据 update

·使用UPDATE 语句更新数据。

       UPDATE  table

       SET  column = value [, column= value, ...]

       [WHERE   condition];


·可以一次更新多条数据。


使用 WHERE 子句指定需要更新的数据

如果省略WHERE子句,则表中的所有数据都将被更新



可在update中使用子查询


删除:delete

SQL> --删除:delete
SQL> delete from emp10;


已删除3行。


SQL> truncate table emp20;


表被截断。


SQL> /*
SQL> 1. delete逐条删除;truncate先摧毁,再重建
SQL> 2. delete 不会释放空间;truncate会
SQL> 3. delete会产生碎片;truncate不会
SQL> 4. deleted可以闪回;truncate不可以闪回

SQL> */
SQL> select * from emp;


     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO                                                                 
---------- ---------- --------- ---------- -------------- ----- ---------- ----------                                                                 
      7369 SMITH      CLERK           7902 17-12月-80       800                    20                                                                 
      7499 ALLEN      SALESMAN        7698 20-2月 -81      1600        300         30                                                                 
      7521 WARD       SALESMAN        7698 22-2月 -81      1250        500         30                                                                 
      7566 JONES      MANAGER         7839 02-4月 -81      2975                    20                                                                 
      7654 MARTIN     SALESMAN        7698 28-9月 -81      1250       1400         30                                                                 
      7698 BLAKE      MANAGER         7839 01-5月 -81      2850                    30                                                                 
      7782 CLARK      MANAGER         7839 09-6月 -81      2450                    10                                                                 
      7788 SCOTT      ANALYST         7566 13-7月 -87      3000                    20                                                                 
      7839 KING       PRESIDENT            17-11月-81      5000                    10                                                                 
      7844 TURNER     SALESMAN        7698 08-9月 -81      1500          0         30                                                                 
      7876 ADAMS      CLERK           7788 13-7月 -87      1100                    20                                                                 


     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO                                                                 
---------- ---------- --------- ---------- -------------- ----- ---------- ----------                                                                 
      7900 JAMES      CLERK           7698 03-12月-81       950                    30                                                                 
      7902 FORD       ANALYST         7566 03-12月-81      3000                    20                                                                 
      7934 MILLER     CLERK           7782 23-1月 -82      1300                    10                                                                 


已选择14行。


SQL> set feedback off
SQL> select * from emp;


     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO                                                                 
---------- ---------- --------- ---------- -------------- ----- ---------- ----------                                                                 
      7369 SMITH      CLERK           7902 17-12月-80       800                    20                                                                 
      7499 ALLEN      SALESMAN        7698 20-2月 -81      1600        300         30                                                                 
      7521 WARD       SALESMAN        7698 22-2月 -81      1250        500         30                                                                 
      7566 JONES      MANAGER         7839 02-4月 -81      2975                    20                                                                 
      7654 MARTIN     SALESMAN        7698 28-9月 -81      1250       1400         30                                                                 
      7698 BLAKE      MANAGER         7839 01-5月 -81      2850                    30                                                                 
      7782 CLARK      MANAGER         7839 09-6月 -81      2450                    10                                                                 
      7788 SCOTT      ANALYST         7566 13-7月 -87      3000                    20                                                                 
      7839 KING       PRESIDENT            17-11月-81      5000                    10                                                                 
      7844 TURNER     SALESMAN        7698 08-9月 -81      1500          0         30                                                                 
      7876 ADAMS      CLERK           7788 13-7月 -87      1100                    20                                                                 


     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO                                                                 
---------- ---------- --------- ---------- -------------- ----- ---------- ----------                                                                 
      7900 JAMES      CLERK           7698 03-12月-81       950                    30                                                                 
      7902 FORD       ANALYST         7566 03-12月-81      3000                    20                                                                 
      7934 MILLER     CLERK           7782 23-1月 -82      1300                    10                                                                 
SQL> @c:\sql.sql
SQL> select count(*) from testdelete;


  COUNT(*)                                                                                                                                            
----------                                                                                                                                            
      5000                                                                                                                                            
SQL> set timing on
SQL> delete from testdelete;;
delete from testdelete;
                      *
第 1 行出现错误: 
ORA-00911: 无效字符 




已用时间:  00: 00: 00.00
SQL> delete from testdelete;
已用时间:  00: 00: 00.04
SQL> drop table testdelete purge;
已用时间:  00: 00: 01.36
SQL> set timing on
SQL> set timing off
SQL>  @c:\sql.sql
SQL> set timing on
SQL> truncate table testdelete;
已用时间:  00: 00: 03.21
SQL> set timing off
SQL> host cls



Oracle中的事务

事务知识点

数据库事务由以下的部分组成:

一个或多个DML 语句
一个DDL(Data Definition Language – 数据定义语言) 语句
一个DCL(Data Control Language – 数据控制语言) 语句



1. 起始标志: DML语句-自动开启
2. 结束标志:提交: 显式提交 commit
                   隐式提交: DDL(create table,drop user,..)
                  回滚:显式回滚 rollback

                  隐式回滚: 掉电,宕机,非正常退出



使用COMMIT ROLLBACK语句,我们可以:

l确保数据完整性。
l数据改变被提交之前预览。
l将逻辑上相关的操作分组。


自动提交在以下情况中执行:
      ?DDL 语句。
      ?DCL 语句。
      ?不使用 COMMIT 或 ROLLBACK 语句提交或回滚,正常结束会话exit。
会话异常结束或系统异常会导致自动回滚。



保存点

使用SAVEPOINT 语句在当前事务中创建保存点。
使用ROLLBACK TOSAVEPOINT 语句回滚到创建的保存点。



SQL> create table testsavepoint

  2  (tid number,tname varchar2(20));
SQL> set feedback on
SQL> insert into testsavepoint values(1,‘Tom‘);


已创建 1 行。


SQL> insert into testsavepoint values(2,‘Mary‘);


已创建 1 行。


SQL> savepoint a;


保存点已创建。


SQL> insert into testsavepoint values(3,‘Mike‘);


已创建 1 行。


SQL> rollback to savepoint a;


回退已完成。


SQL> select * from testsavepoint;


       TID TNAME                                                                                                                                      
---------- --------------------                                                                                                                       
         1 Tom                                                                                                                                        
         2 Mary                                                                                                                                       


已选择2行。


SQL> commit;


提交完成。

JDBC中如何使用保存点

SQL> /*
SQL> JDBC中使用存储点
SQL> Connection conn = ...
SQL> conn.setAutoCommit(false);
SQL> Savepoint sp = conn.setSavepoint("aaa")
SQL> DML
SQL> 
SQL> conn.rollback(sp);
SQL> */
SQL> spool off

Oracle学习(8):处理数据

标签:oracle   学习笔记   数据库   

原文地址:http://blog.csdn.net/qhwc2009/article/details/46304941

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!