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

首頁 > 學院 > 開發設計 > 正文

Order by 的數值型靈活使用

2019-11-17 05:38:39
字體:
來源:轉載
供稿:網友

  代碼:
select * from table_a where id=p_id order by decode(函數,'asc',1,'desc',-1)*jsny;  

控制試圖的訪問時間:
6. 代碼:
create view ...
as
select ... from where exists(select x from dual where sysdate>=8:00am and sysdate<=5:00pm)

妙用decode實現排序
代碼:
select * from tabname
order by decode(mode,'FIFO',1,-1)*to_char(rq,'yyyymmddhh24miss');
select * from tabname
order by decode(mode,'FIFO',rq-sysdate, sysdate-rq)  
找出某個時期內工作日數:
代碼:
select count(*)
from ( select rownum-1 rnum
from all_objects
where rownum <= to_date('2002-02-28','yyyy-mm-dd') - to_date('2002-
02-01','yyyy-mm-dd')+1 )
where to_char( to_date('2002-02-01','yyyy-mm-dd')+rnum-1, 'D' ) not
in ( '1', '7' )

我覺得查詢重復記錄的語句就很經典
代碼:
select rowid,bdsszd from BADWDJ a where a.rowid != (select max(rowid) from BADWDJ b where a.bdsszd =b.bdsszd)  
由它引申的就有很多有用的語句,如昨天回答別人的排序的難題
代碼:
select id,bdsszd from BADWDJ a where a.id = (select max(id) from BADWDJ b where a.bdsszd =b.bdsszd) order by id

樹型結構表的查詢:
代碼:
select ID,PARENT_ID from parent_child
connect by PRior id = parent_id
start with id = 1;

1.decode這個函數一定需要會,我覺得sql的靈活很多地方都是通過這個function來體現的,相當于if,很好用。
2.group by,這個東東想想簡單,其實好多統計功能是離不開這個操作的。Oracle8中擴充了group by rollup和cube的操作。有時候省了你好多功夫的。值得注重的是,當你對事物做過有效的人為歸并之后執行group by 往往會更讓人心曠神怡。
3.很表豎置的經典寫法,也要記?。?代碼:
sum(decode( )) group by ...
注重:需要在一個subquery中確定一個橫置判點。
4.樹形結構表的遍歷寫法: 代碼:
select ...from ....
start with ... connect by prior  
(父子關系表達式)
代碼:
select * from xxx where decode(:var,null,'0',column1) = decode(:var,null,'0',:var);

816以上的 一些分析函數如 rank() over() and row_number() over()
當然關于 group by rollup/cube使用的人恐怕非凡少
如何實現最大匹配的操作?
例如:給定字符串 '1234', 而表中可能有記錄項'1','12','123','1234','12345',要選出'1234'項
代碼:
select * from (
select col_FT from table_FT
where instr('12345',col_FT)=1
order by length(col_FT) desc)
where rownum =1

給你一個意想不到的東西

代碼:
SQL> select to_char(to_date(12,'yyyy'),'year') from dual;
TO_CHAR(TO_DATE(12,'YYYY'),'YEAR')
------------------------------------------
twelve
select to_char(sysdate,'day') from dual
還有 d、iw、mm等等格式
對于translate函數有一個功能
比如:找出某個字符串中完全是數字
代碼:
select * from xxx where translate(column1,'1234567890','') = column1;
select trunc(sysdate) from dual;

select trunc(sysdate,'mm') from dual;
大家構造幾個例子看看就能明白
代碼:
select a,b,sum(c) from xxx group by rollup(a,b);
select a,b,sum(c) from xxx group by cube(a,b);

怎么查找字符串里面包含有%的記錄:
當然,常規方法就是利用 escape了
可假如不知道escape也行,比如
代碼:
select * from xxx where replace(a,'%','') = a;

利用decode解決動態sql的不確定條件查詢的問題:
假設前臺傳入的都是變量
代碼:
select * from xxx where decode(:var,null,'0',column1) = decode(:var,null,'0',:var);
這樣比 like :var'%' 效率高
另:對于
代碼:
select ...
from a,b
where a.a = b.a(+) and b.a is null;
我想對于不明白的朋友,我要交代一下用處才好:
比如,你需要查找在a表中有而b表中沒有的記錄
也許你會選擇 not in:
select * from a aa where aa.a1 not in (select a1 from bb);
這是效率最低的
或者:
select a1 from aa
minus
select a1 from bb;
所有這些寫法,都不如下面下率高:
代碼:
select a.* from aa a,bb b
where a.a1 = b.a1(+) and b.a1 is null;
給一個很普通的適用的最高效的外連接例子(不是什么新鮮玩意):
select ...
from a,b
where a.a = b.a(+) and b.a is null;
我要按年齡段(小于20,20-30,---)統計人數,我可以用
代碼:
select
sum(decode(sign(age - 20),-1,1,0)),
sum(decode(sign(age - 20),-1,0,(decode(sign(age - 30,-1,1,0))))),
sum(decode(sign(age - 30),-1,0,(decode(sign(age - 40,-1,1,0))))),
sum(decode(sign(age - 40),-1,0,(decode(sign(age - 50,-1,1,0))))),
sum(decode(sign(age - 50),-1,0,1))
from xxx;
這樣只做一遍表掃描
這是分了20以下和50以上的
類似的問題,自己擴展了
添加行號:
代碼:
select (select count(*) from a1 where item <= a.item) AS ROW, * FROM a1 as a order by item
select * from table1 a
where id in (select top 3 from table1 where 物品=a.物品 order by price desc)

每一種物品有很多價格,每一種物品選擇排在前三的紀錄
1。job的使用:
代碼:
DBMS_JOB.SUBM99v(:jobno,//job號
'your_procedure;',//要執行的過程
trunc(sysdate)+1/24,//下次執行時間
'trunc(sysdate)+1/24+1'//每次間隔時間
);
刪除job:dbms_job.remove(jobno);
修改要執行的操作:job:dbms_job.what(jobno,what);
修改下次執行時間:dbms_job.next_date(job,next_date);
修改間隔時間:dbms_job.interval(job,interval);
停止job:dbms.broken(job,broken,nextdate);
啟動job:dbms_job.run(jobno);
例子:
代碼:
VARIABLE jobno number;
begin
DBMS_JOB.SUBM99v(:jobno,
'Procdemo;',//Procdemo為過程名稱
SYSDATE, 'SYSDATE + 1/720');
commit;
end;
/
2。把一個表放在內存里
alter table tablename cache.
3。創建臨時表
代碼:
CREATE GLOBAL TEMPORARY TABLE TABLENAME (
COL1 VARCHAR2(10),
COL2 NUMBER
) ON COMM99v PRESERVE(DELETE) ROWS ;
這種臨時表不占用表空間,而且不同的session之間互相看不到對方的數據
在會話結束后表中的數據自動清空,假如選了DELETE ROWS,則在提交的時候即清

空數據,PRESERVE則一直到會話結束
4。加一個自動增加的id號
第一種方法:
第一步:創建SEQUENCE
代碼:
create sequence s_country_id increment by 1 start with 1 maxvalue  

999999999;
第二步:創建一個基于該表的before insert 觸發器,在觸發器中使用該
代碼:
SEQUENCE
create or replace trigger bef_ins_t_country_define
before insert on t_country_define
referencing old as old new as new for each row
begin
select s_country_id.nextval into :new.country_id from dual;
end;
/
第二種方法:
代碼:
CREATE OR REPLACE TRIGGER TR1
BEFORE INSERT ON temp_table
FOR EACH ROW
declare
com_num NUMBER;
BEGIN
SELECT MAX(ID) INTO COM_NUM FROM TEMP_TABLE;
:NEW.ID:=COM_NUM+1;
END TR1;
/
5。限制用戶登錄:創建一個概要文件
create profile CLERK_PROFILE limit
session_per_user 1 #用戶可擁有的會話次數
idle_time 10 #進程處于空閑狀態的時間(10分鐘)
然后就可以將該概要文件授予一個用戶
alter user A profile CLERK_PROFILE;
6。使觸發器為無效alter trigger yourtriggername disable
假如是對于某一個表的所有的觸發器:
alter table yourtablename disable all triggers

更改數據庫時間顯示格式:
SQL> alter session set nls_date_format = 'YYYY-MM-DD HH24:MI:SS';
會話已更改。
1. 選取 TOP N 行記錄
代碼

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品91免费在线| 91亚洲精品在线观看| 亚洲第一精品自拍| 欧美成人三级视频网站| 精品国产依人香蕉在线精品| 亚洲成av人乱码色午夜| 亚洲国产精久久久久久| 国产一区二区三区在线| 久久精品这里热有精品| 亚洲午夜精品视频| 国产精品中文久久久久久久| 精品国产1区2区| 91日韩在线播放| 国产亚洲精品久久久久久牛牛| 欧美日韩在线看| 亚洲午夜av电影| 69国产精品成人在线播放| 日韩欧美在线免费观看| 国产精品第七影院| 亚洲成人激情在线| 亚洲a级在线观看| 国内精品一区二区三区| 在线看日韩欧美| 高清亚洲成在人网站天堂| 91免费看片网站| 亚洲视频自拍偷拍| 亚洲第一精品夜夜躁人人爽| 国产色视频一区| 精品亚洲一区二区三区在线观看| 欧美性jizz18性欧美| 久久久久久尹人网香蕉| 日本aⅴ大伊香蕉精品视频| 色琪琪综合男人的天堂aⅴ视频| 中文字幕av一区| 欧美激情成人在线视频| 亚洲视频专区在线| 亚洲精品乱码久久久久久金桔影视| 精品国产31久久久久久| 夜夜嗨av色综合久久久综合网| 国产精品久久电影观看| 久久精品视频一| 51午夜精品视频| 日韩欧美中文免费| 亚洲欧美变态国产另类| 色在人av网站天堂精品| 美女国内精品自产拍在线播放| 97久久精品视频| 国产精品444| 精品国产欧美一区二区五十路| 久久精品视频播放| 亚洲欧美资源在线| 国外成人在线播放| 91在线观看免费观看| 亚洲国产精品成人一区二区| 亚洲成人激情在线观看| 国产在线拍偷自揄拍精品| 成人观看高清在线观看免费| 亚洲视频国产视频| 亚洲一区亚洲二区亚洲三区| 亚洲色图日韩av| 亚洲午夜精品久久久久久久久久久久| 久久影院资源站| 亚洲图中文字幕| 久久久精品一区二区| 中文字幕自拍vr一区二区三区| 亚洲一区二区三区香蕉| 免费97视频在线精品国自产拍| 国产精品久久久久久久电影| 欧美日韩国产精品一区| 午夜精品久久久久久久99黑人| 91理论片午午论夜理片久久| 伊人男人综合视频网| 美女久久久久久久| 亚洲第一天堂无码专区| 亚洲美女免费精品视频在线观看| 欧美中文在线观看国产| 国产婷婷97碰碰久久人人蜜臀| 国产成人精品一区二区三区| 国产中文字幕亚洲| 国产精品日韩专区| 欧美成人在线网站| 成人黄色免费片| 日本精品一区二区三区在线| 狠狠色狠狠色综合日日五| 亚洲欧美日韩第一区| 美女啪啪无遮挡免费久久网站| 黑人巨大精品欧美一区免费视频| 久久久中文字幕| 亚洲国产精品悠悠久久琪琪| 日韩欧美亚洲综合| 青青草国产精品一区二区| 国产99在线|中文| 一本一本久久a久久精品牛牛影视| 成人国产精品一区二区| 成人精品视频在线| 精品丝袜一区二区三区| 国a精品视频大全| 日韩精品黄色网| 亚洲女同精品视频| 91精品视频在线看| 日韩美女写真福利在线观看| 国产亚洲激情视频在线| 亚洲影影院av| www.日韩不卡电影av| 久久精品国产视频| 成人av在线网址| 国产欧美一区二区三区四区| 精品国产999| 国产精品a久久久久久| 欧美精品久久久久久久久久| 国产精品www色诱视频| 国产视频精品一区二区三区| 色偷偷av亚洲男人的天堂| 日日噜噜噜夜夜爽亚洲精品| 日韩欧美亚洲综合| 91中文精品字幕在线视频| 中文字幕亚洲欧美日韩2019| 亚洲图片在线综合| 久久91精品国产91久久久| 亚洲欧美国产精品| 亚洲黄色www网站| 亚洲国产精品免费| 日本一欧美一欧美一亚洲视频| 欧美午夜激情在线| 精品视频在线观看日韩| 亚洲xxxx做受欧美| 久久全球大尺度高清视频| 亚洲国产欧美一区二区三区久久| 欧美视频专区一二在线观看| 成人亚洲综合色就1024| 欧美诱惑福利视频| 亚洲免费福利视频| 国产精品视频白浆免费视频| 日韩av色在线| 国产成人精品久久二区二区| 91精品国产自产91精品| 亚洲电影中文字幕| 欧美激情一区二区三区久久久| 91精品国产电影| 成人黄在线观看| 亚洲一区二区三区四区视频| 亚洲精品av在线播放| 欧美一区二区三区免费观看| 亚洲第一男人天堂| 国产亚洲一级高清| 国产欧美日韩免费| 美女福利精品视频| 亚洲人精品午夜在线观看| 国产精品亚洲美女av网站| 影音先锋欧美精品| 欧美中文字幕在线观看| 亚洲三级av在线| 亚洲石原莉奈一区二区在线观看| 在线观看成人黄色| 亚洲精品国产福利| 国产精品免费一区豆花| 亚洲国产99精品国自产| 中文精品99久久国产香蕉| 国产精品91在线观看| 国产一区二区三区精品久久久| 欧美激情综合色| 日韩精品高清在线| 不卡伊人av在线播放| 欧亚精品中文字幕|