亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

我的oracle筆記一(sql語句方面)

2024-08-29 13:49:40
字體:
來源:轉載
供稿:網友
一.sql語句1.增加主鍵
   alter table TABLE_NAME add constraint KEY_NAME PRimary key (TABLE_COLUMN);
   指定表空間
   alter table TABLE_NAME add constraint KEY_NAME primary key (TABLE_COLUMN) using index  tablespace TABLE_SPACE_NAME;
2.增加外鍵
   alter table TABLE_NAME add constraint FK_NAME  foreign key (TABLE_COLUMN) references KEY_TABLE_NAME;
3.使主鍵或外鍵失效、生效
   alter table TABLE_NAME  disable(enable) constraint KEY_NAME;
4、查看各種約束
  select constraint_name,table_name,constraint_type,status from user_constraints;
  select constraint_name, constraint_type,search_condition, r_constraint_name  from user_constraints where table_name = upper('&table_name')  select c.constraint_name,c.constraint_type,cc.column_name 
     from user_constraints c,user_cons_columns cc
     where c.owner = upper('&table_owner') and c.table_name = upper('&table_name')
     and c.owner = cc.owner and c.constraint_name = cc.constraint_name
     order by cc.position; 5、刪除主鍵或外鍵
  alter table TABLE_NAME  drop constraint KEY_NAME;
6、建外鍵
    單字段時:create table 表名 (col1  char(8),
                                 cno   char(4)  REFERENCE course);
    多個字段時,在最后加上 Foreign Key (字段名) REFERENCE 表名(字段)
    連帶刪除選項 (on delete cascade
       當指定時,假如父表中的記錄被刪除,則依靠于父表的記錄也被刪除
             REFERENCE 表名() on delete cascade;
7、刪除帶約束的表
    Drop table 表名 cascade  constraints;8:索引治理
<1>.creating function-based indexes
sql> create index summit.item_quantity on summit.item(quantity-quantity_shipped); <2>.create a B-tree index
sql> create [unique] index index_name on table_name(column,.. asc/desc) tablespace
sql> tablespace_name [pctfree integer] [initrans integer] [maxtrans integer]
sql> [logging nologging] [nosort] storage(initial 200k next 200k pctincrease 0
sql> maxextents 50); <3>.pctfree(index)=(maximum number of rows-initial number of rows)*100/maximum number of rows <4>.creating reverse key indexes
sql> create unique index xay_id on xay(a) reverse pctfree 30 storage(initial 200k
sql> next 200k pctincrease 0 maxextents 50) tablespace indx; <5>.create bitmap index
sql> create bitmap index xay_id on xay(a) pctfree 30 storage( initial 200k next 200k
sql> pctincrease 0 maxextents 50) tablespace indx; <6>.change storage parameter of index
sql> alter index xay_id storage (next 400k maxextents 100); 7.allocating index space

sql> alter index xay_id allocate extent(size 200k datafile 'c:/Oracle/index.dbf'); <8>.alter index xay_id deallocate unused; <9>、查看索引
     SQL>select index_name,index_type,table_name from user_indexes order by table_name;
<10>、查看索引被索引的字段
     SQL>select * from user_ind_columns where index_name=upper('&index_name');11、創建序列
    select * from user_sequences;
    create  sequence SEQ_NAME  start with 1000
         maxvalue  1000 increment by 1;
    alter sequence  SEQ_NAME minvalue 50 maxvalue 100;
12、刪除重復行
    update a set aa=null where aa is not null;
   
    delete from a where rowid!=
        (select max(rowid) from a  b where  a.aa=b.aa);
13、刪除同其他表相同的行
    delete from a  where exits
      (select 'X' from b where b.no=a.no);
    或
      delete from a  where no in (select no from b);
14、查詢從多少行到多少行的記錄(可以用在web開發中的分頁顯示) select * from ( select rownum row_id,b.* from (select a.* from sys_oper a) b )
 where row_id between 15 and 2015、對公共授予訪問權
    grant select on 表名 to public;
    create public synonym 同義詞名  for 表名;
16、填加注釋
    comment on table 表名 is  '注釋';
    comment on column 表名.列名 is '注釋';
17、分布式數據庫,創建數據庫鏈路
    create [public] database link LINKNAME
       [connect to USERNAME identified by PASSWord]
       [using 'CONNECT_STRING']
    可以在服務器端,也可以在客戶端建立,但必須注重,兩臺服務器之間
    數據庫必須可以互訪,必須各有各自的別名數據庫
18、查看數據庫鏈路
    select * from  all_db_links;
    select * from user_db_links;
    查詢  select * from TABLENAME@DBLNKNAME;
    創建遠程數據庫同義詞
       create synonym  for TABLENAME@DBLNKNAME;
    操縱遠程數據庫記錄
      insert into TABLENAME@DBLNKNAME (a,b)  values (va,vb);
      update    TABLENAME@DBLNKNAME  set a='this';
      delete from TABLENAME@DBLNKNAME;

   怎樣執行遠程的內嵌過程
       begin
         otherdbpro@to_html(參數);
       end;19、數據庫鏈路用戶密碼有非凡字符的時候,可以用雙引號把密碼引起來
create public database link dblink1 connect to db1 identified by "123*456" using 'db11'20.oracle8中擴充了group by rollup和cube的操作。有時候省了你好多功夫的。
 <1>下面的語句可以進行總計
 select region_code,count(*) from aicbs.acc_woff_notify
 group by rollup(region_code);
 <2> 對第1個字段小計,最后合計
 select region_code,write_status,count(*) from aicbs.acc_woff_notify
 group by rollup(region_code,write_status);
 ----------------------
  570     0       3
  570     1       2
  570             5   --此處小計了570的記錄
  571     0       10
  571     1       2
  571             12  --此處小計了571的記錄
  .....
      100 --此處有總計
 <3> 復合rollup表達式,只做總計
 select region_code,write_status,count(*) from aicbs.acc_woff_notify
 group by rollup(region_code,write_status);
   
 <4> 對第1個字段小計,再對第2個字段小計,最后合計
 select region_code,write_status,count(*) from aicbs.acc_woff_notify
 group by cube(region_code,write_status);
 ----------------------
      100  --此處有總計
    0  60  --對write_status=0的小計
    1  39  --對write_status=1的小計
    3  1  --對write_status=3的小計
  570    5  --此處小計了570的記錄
  570  0  3
  570  1  2
  571    12  --此處小計了571的記錄
  571  0  10
  571  1  2
  ....
 <3> 復合cube表達式,只做總計
 select region_code,write_status,count(*) from aicbs.acc_woff_notify
 group by cube(region_code,write_status);
   
 
 <4>下面的語句可以按照rollup不同的字段進行小計
 select region_code,write_status,count(*) from aicbs.acc_woff_notify
 group by region_code,rollup(write_status);
21.查詢view的創建語句
  sql>set long 1000
  sql>select * from user_views where view_name='MY_VIEW_NAME';
   or
 sql>select * from all_views where view_name='MY_VIEW_NAME';22、去除數據庫中非凡字符

 <1>.字符串字段中含有"'",假如用來組合sql語句,會造成語句不準確。
     比如:replace(f1,'''','')
 <2>.字符串字段中含有"/t /n",假如用來在c或者c++程序中輸出到文件,格式無法保證。
  比如:replace(f2,'/t','')
 <3>.清除換行和回車
  比如: replace(f2,chr(13)chr(10),'')
23、如何在字符串里加回車或者tab鍵
  在sqlplus中執行
   sql>select 'UserId=1233111'chr(10)'AccId=13431'chr(9)'AccId2=11111' from dual;24、樹形查詢
create table zj(
bm     number(8),
bmmc   varchar2(20),
sjbm   number(8)
)insert into zj values(1,'aaa',0)
insert into zj values(11,'aaa1',1)
insert into zj values(12,'aaa2',1)
insert into zj values(111,'aaa11',11)
insert into zj values(112,'aaa12',11)
insert into zj values(113,'aaa13',11)
insert into zj values(121,'aaa21',12)
insert into zj values(122,'aaa22',12)
insert into zj values(123,'aaa23',12)
--
select bm,bmmc,sjbm,level
from zj
start with sjbm=0
connect by prior  bm = sjbm
或者select bm,bmmc,sjbm,level
from zj
start with sjbm=0
connect by  sjbm = prior  bm
25、快照
    create snapshot SNAPSHOT_NAME
       [storage (storage parameter)]
       [tablespace  TABLESPACE_NAME]
       [refresh  [fast/complete/force]
       [start with  START_DATE next NEXT_DATE]
       as QUERY;
  
   create snapshot snapshot_to_study as select * from TABLE_NAME@to_study;
   創建角色
     create role aa identified by aaa;
   授權  grant create snapshot,alter snapshot to aaa;
         grant  aaa to emp;
   create snapshot SNAPSHOT_TO_Html refresh  complete start with sysdate next
       sysdate+5/(24*60*60) as  select * from a@to_html;
   刪除  drop snapshot snap_to_html
   手工刷新快照,(調用DBMS_SNAPSHOT包中的refresh過程)DBMS_SNAPSHOT.refresh(snapshot_name,refresh_type);
       begin
          DBMS_SNAPSHOT.REFRESH('snap_to_html','c');
       end;
   對所有快照進行刷新
       begin
          DBMS_SNAPSHOT.REFRESH_ALL;
       end;
   怎樣執行遠程的內嵌過程
       begin
         otherdbpro@to_html(參數);

       end;
26、用戶治理
 create a user: database authentication
  sql> create user juncky identified by oracle default tablespace users
  sql> temporary tablespace temp quota 10m on data password eXPire
  sql> [account lockunlock] [profile profilenamedefault];  <1>.查看當前用戶的缺省表空間
 SQL>select username,default_tablespace from user_users;
 <2>生成用戶時指定缺省表空間
  create user 用戶名 identified by 口令  default      tablespace 表空間名;
  
 <3>重新指定用戶的缺省表空間
      alter user 用戶名 default tablespace 表空間名
 <4>查看當前用戶的角色
 SQL>select * from user_role_privs;
 <5>查看當前用戶的系統權限和表級權限
  SQL>select * from user_sys_privs;
  SQL>select * from user_tab_privs;
 <6>查看用戶下所有的表
      SQL>select * from user_tables;
 <7> alter user語句的quota子句限制用戶的磁盤空間
     如:alter user jf  quota 10M  on system;
27、查看放在ORACLE的內存區里的表  
     SQL>select table_name,cache from user_tables where instr(cache,'Y')>0;28、約束條件
    create table employee
     (empno  number(10)  primary key,
      name   varchar2(40) not null,
      deptno  number(2)  default 10,
      salary  number(7,2)  check  salary<10000,
      birth_date date,
      soc_see_num  char(9)  unique,
      foreign key(deptno) references dept.deptno)
      tablespace users;
     
    要害字(primary key)必須是非空,表中記錄的唯一性
    not null  非空約束
    default   缺省值約束
    check     檢查約束,使列的值符合一定的標準范圍
    unqiue  唯一性約束
    foreign key 外部鍵約束29、查看創建視圖的select語句
     SQL>set view_name,text_length from user_views;
     SQL>set long 2000;  說明:可以根據視圖的text_length值設定set long 的大小
     SQL>select text from user_views where view_name=upper('&view_name');30、查看同義詞的名稱
     SQL>select * from user_synonyms;31、用Sql語句實現查找一列中第N大值
select * from
(select t.*,dense_rank() over (order by sal) rank from employee)
where rank = N;32 虛擬自段
  <1>. CURRVAL 和 nextval
   為表創建序列
   CREATE SEQUENCE EMPSEQ ... ;

   SELECT empseq.currval FROM DUAL ;
   自動插入序列的數值
   INSERT INTO emp
        VALUES (empseq.nextval, 'LEWIS', 'CLERK',
                7902, SYSDATE, 1200, NULL, 20) ;   <2>. ROWNUM
    按設定排序的行的序號
    SELECT * FROM emp WHERE ROWNUM < 10 ;   <3>. ROWID
    返回行的物理地址
    SELECT ROWID, ename FROM emp  WHERE deptno = 20 ;33、對CLOB字段進行全文檢索
SELECT * FROM A WHERE dbms_lob.instr(a.a,'K',1,1)>0;34. 非凡字符的插入,比如"&"
insert into a values (translate ('at{&}t','at{}','at')); 35.表治理
 <1>.create a table
 sql> create table table_name (column datatype,column datatype]....)
 sql> tablespace tablespace_name [pctfree integer] [pctused integer]
 sql> [initrans integer] [maxtrans integer]
 sql> storage(initial 200k next 200k pctincrease 0 maxextents 50)
 sql> [loggingnologging] [cachenocache]  <2>.copy an existing table
 sql> create table table_name [loggingnologging] as subquery
 
 <3> create table ... as 方式建表的時候,指定表參數
    create table a
      storage(
              initial 1M   /*第一次創建時分配空間*/
              next 1M      /*第一次分配的存儲空間用完時在分配*/
              )
              as  select * from b;
 <4>.創建臨時表
 sql> create global temporary table xay_temp as select * from xay;
  on commit preserve rows/on commit delete rows
 在Oracle中,可以創建以下兩種臨時表:
   a 會話特有的臨時表:
 create global temporary table () on commit preserve rows;
 會話指定,當中斷會話時ORACLE將截斷表   b 事務特有的臨時表:
 create global temporary table () on commit delete rows;
 事務指定,每次提交后ORACLE將截斷表(刪除全部行)
   c 說明
    臨時表只在當前連接內有效
  臨時表不建立索引,所以假如數據量比較大或進行多次查詢時,不推薦使用
  數據處理比較復雜的時候時表快,反之視圖快點
  在僅僅查詢數據的時候建議用游標: open cursor for 'sql clause';
 <5>
    pctfree = (average row size - initial row size) *100 /average row size
    pctused = 100-pctfree- (average row size*100/available data space)
 <6>.change storage and block utilization parameter
 sql> alter table table_name pctfree=30 pctused=50 storage(next 500k
 sql> minextents 2 maxextents 100);

 <7>.manually allocating extents
 sql> alter table table_name allocate extent(size 500k datafile 'c:/oracle/data.dbf');
 <8>.move tablespace
 sql> alter table employee move tablespace users;
 <9>.deallocate of unused space
 sql> alter table table_name deallocate unused [keep integer]
 <10>.drop a column
 sql> alter table table_name drop column comments cascade constraints checkpoint 1000;
 alter table table_name drop columns continue;
 <11>.mark a column as unused
 sql> alter table table_name set unused column comments cascade constraints;
  alter table table_name drop unused columns checkpoint 1000;
  alter table orders drop columns continue checkpoint 1000
  data_dictionary : dba_unused_col_tabs37. 中文是如何排序的? Oracle9i之前,中文是按照二進制編碼進行排序的。
在oracle9i中新增了按照拼音、部首、筆畫排序功能。設置NLS_SORT值
SCHINESE_RADICAL_M 按照部首(第一順序)、筆劃(第二順序)排序
SCHINESE_STROKE_M 按照筆劃(第一順序)、部首(第二順序)排序
SCHINESE_PINYIN_M 按照拼音排序 38. 數據表中的字段最大數:
表或視圖中的最大列數為 1000
39. oracle中的裸設備:
  裸設備就是繞過文件系統直接訪問的儲存空間40. 在Oracle服務器上通過SQLPLUS查看本機IP地址 ?
select sys_context('userenv','ip_address') from dual;
假如是登陸本機數據庫,只能返回127.0.0.141. 在ORACLE中取毫秒?
   9i之前不支持,9i開始有timestamp.
   9i可以用select systimestamp from dual;42. 將N秒轉換為時分秒格式?
   set serverout on
   declare
   N number := 1000000;
   ret varchar2(100);
   begin
   ret := trunc(n/3600) '小時' to_char(to_date(mod(n,3600),'sssss'),'fmmi"分   "ss"秒"') ;
   dbms_output.put_line(ret);
   end; 43、在某個用戶下找所有的索引
   select user_indexes.table_name, user_indexes.index_name,uniqueness, column_name
   from user_ind_columns, user_indexes
   where user_ind_columns.index_name = user_indexes.index_name
   and user_ind_columns.table_name = user_indexes.table_name
   order by user_indexes.table_type, user_indexes.table_name,
   user_indexes.index_name, column_position;
44. not in的替代。
   一般not in的效率比較低。非凡是數據量大的時候,幾乎不能執行。
   用下面幾種方式可以替換寫法
   比如要查詢在fee_rev_info表中已經銷戶的用戶(不在cm_user中的)(不過下面的例子不是很好,因為bill_id是cm_user的唯一索引)
   select * from fee_rev_info where bill_id not in (select bill_id from cm_user)  
   <1> 用not exists
   select * from fee_rev_info a where not exists (select 'p' from cm_user b where b.bill_id = a.bill_id)
   <2> 用外連接(+)
 select a.* from fee_rev_info a,cm_user b
 where a.bill_id = b.bill_id (+)
 and b.bill_id is null
   <3> 用hash_aj
   select /*+HASH_AJ*/* from fee_rev_info where bill_id not in (select bill_id from cm_user)   45.怎么樣查詢非凡字符,如通配符%與_

假如數據庫中有表 STATIONTYPE,STATION_571 STATION_572 ...
select * from tab  where tname like 'STATION_%'
會顯示 STATIONTYPE,STATION_571 ... 可以用下面的語句
select * from tab  where tname like 'STATION/_%' escape'/'46.假如存在就更新,不存在就插入可以用一個語句實現嗎
9i已經支持了,是Merge,但是只支持select子查詢,
假如是單條數據記錄,可以寫作select .... from dual的子查詢。
語法為:
MERGE INTO table
USING data_source
ON (condition)
WHEN MATCHED THEN update_clause
WHEN NOT MATCHED THEN insert_clause;如
MERGE INTO cm_user_credit 
USING (select * from dual) ON (user_id =1302514690 )
when MATCHED then update set credit_value = 1000
when NOT MATCHED then insert (user_id,acc_id,bill_id,plan_id,region_code,credit_value) values(1302514690,1305032158,'13857141218',10070247,'571',1000);47.怎么實現一條記錄根據條件多表插入
9i以上可以通過Insert all語句完成,僅僅是一個語句,如:
INSERT ALL
WHEN (id=1) THEN
INTO table_1 (id, name)
values(id,name)
WHEN (id=2) THEN
INTO table_2 (id, name)
values(id,name)
ELSE
INTO table_other (id, name)
values(id, name)
SELECT id,name
FROM a;假如沒有條件的話,則完成每個表的插入,如
INSERT ALL
INTO table_1 (id, name)
values(id,name)
INTO table_2 (id, name)
values(id,name)
INTO table_other (id, name)
values(id, name)
SELECT id,name
FROM a;48.如何實現行列轉換
<1>、固定列數的行列轉換

student subject grade
---------------------------
student1 語文 80
student1 數學 70
student1 英語 60
student2 語文 90
student2 數學 80
student2 英語 100
...
轉換為
語文 數學 英語
student1 80 70 60
student2 90 80 100
...
語句如下:
select student,sum(decode(subject,'語文', grade,null)) "語文",
sum(decode(subject,'數學', grade,null)) "數學",
sum(decode(subject,'英語', grade,null)) "英語"
from table
group by student<2>、不定列行列轉換

c1 c2
--------------
1 我
1 是
1 誰
2 知
2 道
3 不
...
轉換為
1 我是誰
2 知道
3 不這一類型的轉換必須借助于PL/SQL來完成,這里給一個例子
CREATE OR REPLACE FUNCTION get_c2(tmp_c1 NUMBER)
RETURN VARCHAR2
IS
Col_c2 VARCHAR2(4000);
BEGIN
FOR cur IN (SELECT c2 FROM t WHERE c1=tmp_c1) LOOP
Col_c2 := Col_c2cur.c2;
END LOOP;
Col_c2 := rtrim(Col_c2,1);
RETURN Col_c2;
END;
/
SQL> select distinct c1 ,get_c2(c1) cc2 from table;即可
--例子:
create table okcai_1
(
user_id varchar2(10),
user_number varchar2(10),
user_num number(8)
)
user_id user_number user_num
---------------------
1 123  2
1 456  5
1 789  6
2 11   2
2 22   3
2 33   4
2 44   5
2 55   6
2 66   7
2 77   8
3 1234 1
3 5678 2方式一:
create or replace function get_col(
       p_userId number,
       p_col    number
) return varchar
as
v_tmp varchar2(255);

begin
     select user_numberchr(9)user_num into v_tmp
     from
     (select user_number,user_num,rownum row_id
      from okcai_1
      where user_id = p_userId) a
     where row_id = p_col;
     return ltrim(v_tmp);
     --return v_tmp;
end;然后
select distinct user_id,get_col(user_id,1),get_col(user_id,2),get_col(user_id,3) .... from okcai_1方式二:
create or replace function get_col(
       p_userId number,
       p_col    number
) return varchar
as
v_tmp varchar2(255);
begin
     select user_numberchr(9)user_num into v_tmp
     from
     (select user_number,user_num,rownum row_id
      from okcai_1
      where user_id = p_userId) a
     where row_id = p_col;
     return ltrim(v_tmp);
     --return v_tmp;
end;
select distinct user_id,get_col_new(user_id) from okcai_1;
49.怎么設置存儲過程的調用者權限
普通存儲過程都是所有者權限,假如想設置調用者權限,請參考如下語句
create or replace
procedure ...()
AUTHID CURRENT_USER
As
begin
...
end;50.Oracle有哪些常見要害字
具體信息可以查看v$reserved_words視圖51.怎么查看數據庫參數
<1> show parameter 參數名
如通過show parameter spfile可以查看9i是否使用spfile文件
其中參數名是可以匹配的。
比如show parameter cursor ,則會顯示跟cursor相關的參數
<2>
select * from v$parameter
<3>除了這部分參數,Oracle還有大量隱含參數,可以通過如下語句查看:
SELECT NAME
,VALUE
,decode(isdefault, 'TRUE','Y','N') as "Default"
,decode(ISEM,'TRUE','Y','N') as SesMod
,decode(ISYM,'IMMEDIATE', 'I',
'DEFERRED', 'D',
'FALSE', 'N') as SysMod
,decode(IMOD,'MODIFIED','U',
'SYS_MODIFIED','S','N') as Modified
,decode(IADJ,'TRUE','Y','N') as Adjusted
,description
FROM ( --GV$SYSTEM_PARAMETER
SELECT x.inst_id as instance
,x.indx+1
,ksppinm as NAME
,ksppity
,ksppstvl as VALUE
,ksppstdf as isdefault
,decode(bitand(ksppiflg/256,1),1,'TRUE','FALSE') as ISEM
,decode(bitand(ksppiflg/65536,3),
1,'IMMEDIATE',2,'DEFERRED','FALSE') as ISYM
,decode(bitand(ksppstvf,7),1,'MODIFIED','FALSE') as IMOD
,decode(bitand(ksppstvf,2),2,'TRUE','FALSE') as IADJ
,ksppdesc as DESCRIPTION
FROM x$ksppi x
,x$ksppsv y
WHERE x.indx = y.indx
AND substr(ksppinm,1,1) = '_'
AND x.inst_id = USERENV('Instance')
)
ORDER BY NAME
52.怎樣建立基于函數索引
8i以上版本,確保
Query_rewrite_enabled=true
Query_rewrite_integrity=trusted
Compatible=8.1.0以上
Create index indexname on table (function(field));53.怎么樣移動表或表分區
[A]移動表的語法
Alter table tablename move
[Tablespace new_name

Storage(initial 50M next 50M
pctincrease 0 pctfree 10 pctused 50 initrans 2) nologging]
移動分區的語法
alter table tablename move (partition partname)
[update global indexes]
之后之后必須重建索引
Alter index indexname rebuild
假如表有Lob段,那么正常的Alter不能移動Lob段到別的表空間,而僅僅是移動了表段,可以采用如下的方法移動Lob段
alter table tablename move
lob(lobsegname) store as (tablespace newts);54.怎么樣修改表的列名
[A]9i以上版本可以采用rname命令
ALTER TABLE UserName.TabName
RENAME COLUMN SourceColumn TO DestColumn
9i以下版本可以采用create table …… as select * from SourceTable的方式。
另外,8i以上可以支持刪除列了
ALTER TABLE UserName.TabName
SET UNUSED (ColumnName) CASCADE CONSTRAINTS
ALTER TABLE UserName.TabName
DROP (ColumnName) CASCADE CONSTRAINTS
55.case的用法
在sql語句中
CASE test_value
WHEN expression1 THEN value1
[[WHEN expression2 THEN value2] [...]]
[ELSE default_value]
END 比如1
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  比如2
select
    case
        when  real_charge>=20000 and real_charge<30000 then 5000
        when  real_charge>=30000 and real_charge<40000 then 9000
        when  real_charge>=40000 and real_charge<50000 then 10000
        when  real_charge>=50000 and real_charge<60000 then 14000
        when  real_charge>=60000 and real_charge<70000 then 18000
        when  real_charge>=70000 and real_charge<80000 then 19000
        when  real_charge>=80000 and real_charge<90000 then 24000
        when  real_charge>=90000 and real_charge<100000 then 27000                                                       
        when  real_charge>=100000 and real_charge<110000 then 27000
        when  real_charge>=110000 and real_charge<120000 then 29000              
        when  real_charge>=120000                      then 36000

        else
            0 
    end ,acc_id,user_id,real_charge from okcai_jh_charge_200505在存儲過程中
               case v_strGroupClassCode
                    when  '1'   then
                          v_nAttrNum := v_nAttrNum + 300;
                          v_strAttrFlag := '1'substr(v_strAttrFlag,2,7);
                    when  '2'           then
                          v_nAttrNum := v_nAttrNum + 200;
                          v_strAttrFlag := '2'substr(v_strAttrFlag,2,7);
                    else
                        NULL;
               end case;
注重的是存儲過程和sql語句有的細微差別是用end case,而不是end。語句后面跟";"


上一篇:Oracle 中DECODE 函數的使用簡介

下一篇:我的oracle筆記二(pl/sql 編程方面)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品视频一区二区三区四| 久久久亚洲影院你懂的| 亚洲mm色国产网站| 久久久日本电影| 亚洲美女视频网| 日韩美女视频免费看| 日韩欧美一区二区三区久久| 日本免费一区二区三区视频观看| 97色伦亚洲国产| 亚洲永久在线观看| 色偷偷噜噜噜亚洲男人| 伊人久久精品视频| 亚洲国产欧美在线成人app| 7m第一福利500精品视频| 久久久久久一区二区三区| 最近2019免费中文字幕视频三| 国产一区二区三区久久精品| …久久精品99久久香蕉国产| 欧美国产高跟鞋裸体秀xxxhd| 欧美片一区二区三区| 欧美国产精品人人做人人爱| 精品久久久久久久中文字幕| 日韩欧美在线视频日韩欧美在线视频| 亚洲精品福利视频| 亚洲欧美国产va在线影院| 国内自拍欧美激情| 91精品免费看| 欧美亚洲视频在线看网址| 日韩天堂在线视频| 欧洲亚洲女同hd| www.亚洲男人天堂| 亚洲人免费视频| 欧美在线观看网站| 亚洲精品福利免费在线观看| 日韩视频免费看| 国产一区二区三区日韩欧美| 色七七影院综合| 亚洲欧美国产va在线影院| www.亚洲成人| 7777精品久久久久久| 一本大道香蕉久在线播放29| 成人日韩在线电影| 欧美在线影院在线视频| 国产日韩欧美日韩| 法国裸体一区二区| 国产在线拍偷自揄拍精品| 久久这里只有精品视频首页| 亚洲乱码一区av黑人高潮| 久久人人爽人人爽爽久久| 国精产品一区一区三区有限在线| 亚洲欧洲日产国码av系列天堂| 欧美激情2020午夜免费观看| 欧美自拍大量在线观看| 尤物九九久久国产精品的特点| 亚洲精品动漫100p| 欧美日韩国产专区| 亚洲精品乱码久久久久久金桔影视| 欧美不卡视频一区发布| 国产精品视频精品| 欧美一级电影免费在线观看| 欧美性生交大片免网| 亚洲精品福利免费在线观看| 亚洲国产精品电影| 性欧美激情精品| 欧美精品九九久久| 欧美高清视频在线观看| 岛国视频午夜一区免费在线观看| 国产99视频精品免视看7| 91网站免费看| 亚洲国产精品福利| 欧美色道久久88综合亚洲精品| 国产成人精品一区二区在线| 国产精品久久久久久久久久ktv| 91麻豆国产精品| 亚洲成av人乱码色午夜| 国语自产精品视频在线看一大j8| 久久艹在线视频| 亚洲精品动漫久久久久| 成人免费视频网址| 日韩中文字幕视频在线| 成人av在线天堂| 久久久噜噜噜久久久| 国产精品美女主播在线观看纯欲| 最近2019年手机中文字幕| 欧美视频在线视频| 欧美理论电影网| 久久久91精品国产| 色综合老司机第九色激情| 欧美床上激情在线观看| 久久久久九九九九| 国产欧美日韩中文字幕| 亚洲精品99久久久久中文字幕| 亚洲欧美国产精品专区久久| 欧美高清激情视频| 欧美精品18videosex性欧美| 中文字幕日韩在线播放| 超在线视频97| 欧美日韩精品在线观看| 久久成人精品一区二区三区| 国产91色在线| 亚洲丁香婷深爱综合| 久久久国产精品x99av| 日韩精品视频免费专区在线播放| 久久成年人免费电影| 欧美大片免费观看在线观看网站推荐| 欧美中文在线观看| 亚洲欧洲在线播放| 成人天堂噜噜噜| 国产99视频精品免视看7| 91精品国产免费久久久久久| 欧美老女人xx| 国产日产欧美a一级在线| 欧美性猛交xxxx| 2024亚洲男人天堂| 日韩免费不卡av| 7777kkkk成人观看| 全亚洲最色的网站在线观看| 中文字幕亚洲无线码在线一区| 久久精品亚洲精品| 亚洲色图在线观看| 亚洲国产精品va在看黑人| 91在线无精精品一区二区| 欧美性极品少妇精品网站| 国产欧美va欧美va香蕉在| 日韩美女av在线免费观看| 欧美在线视频观看免费网站| 2019中文字幕在线观看| 亚洲国产私拍精品国模在线观看| 久久精品99无色码中文字幕| 欧美多人乱p欧美4p久久| 日韩在线观看免费全| 91高清视频免费| 久久精品亚洲94久久精品| 海角国产乱辈乱精品视频| 国产欧美日韩综合精品| 欧洲s码亚洲m码精品一区| 日韩av影院在线观看| 亚洲精品视频免费| 久久久亚洲国产天美传媒修理工| 欧美大片在线免费观看| 亚洲精品视频二区| 久久久国产成人精品| 国产精品毛片a∨一区二区三区|国| 日韩国产中文字幕| 国产日韩av在线| 久久久久久久久久久久av| 国产一区二区动漫| 久久久中精品2020中文| 色噜噜国产精品视频一区二区| 国产精品久久久久免费a∨| 26uuu亚洲伊人春色| 久久久国产一区二区三区| 久久久久久噜噜噜久久久精品| 欧美精品在线免费播放| 国产亚洲视频在线| 精品中文字幕久久久久久| 国产精品亚发布| 欧美黑人xxxⅹ高潮交| 夜色77av精品影院| 欧美乱大交xxxxx另类电影| 精品国产91乱高清在线观看| 91av在线影院| 欧美男插女视频| 日韩欧美国产激情|