日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

WITH AS短語,也叫做子查詢部分,可以定義一個(gè)SQL片斷,該SQL片斷會(huì)被整個(gè)SQL語句用到??梢允筍QL語句的可讀性更高,也可以在UNION ALL的不同部分,作為提供數(shù)據(jù)的部分。


SQL語句中的with as該怎么用

–針對一個(gè)別名

with tmp as (select * from tb_name)

–針對多個(gè)別名

with
tmp as (select * from tb_name),
tmp2 as (select * from tb_name2),
tmp3 as (select * from tb_name3),
…

–相當(dāng)于建了個(gè)e臨時(shí)表

with e as (select * from scott.emp e where e.empno=7499)
select * from e;

–相當(dāng)于建了e、d臨時(shí)表

with
e as (select * from scott.emp),
d as (select * from scott.dept)
select * from e, d where e.deptno = d.deptno;

其實(shí)就是把一大堆重復(fù)用到的sql語句放在with as里面,取一個(gè)別名,后面的查詢就可以用它,這樣對于大批量的sql語句起到一個(gè)優(yōu)化的作用,而且清楚明了。


向一張表插入數(shù)據(jù)的with as用法

insert into table2
with
s1 as (select rownum c1 from dual connect by rownum <= 10),
s2 as (select rownum c2 from dual connect by rownum <= 10)
select a.c1, b.c2 from s1 a, s2 b where…;

select s1.sid, s2.sid from s1 ,s2需要有關(guān)聯(lián)條件,不然結(jié)果會(huì)是笛卡爾積。

with as 相當(dāng)于虛擬視圖。

with as短語,也叫做子查詢部分(subquery factoring),可以讓你做很多事情,定義一個(gè)sql片斷,該sql片斷會(huì)被整個(gè)sql語句所用到。有的時(shí)候,是為了讓sql語句的可讀性更高些,也有可能是在union all的不同部分,作為提供數(shù)據(jù)的部分。

特別對于union all比較有用。因?yàn)閡nion all的每個(gè)部分可能相同,但是如果每個(gè)部分都去執(zhí)行一遍的話,則成本太高,所以可以使用with as短語,則只要執(zhí)行一遍即可。如果with as短語所定義的表名被調(diào)用兩次以上,則優(yōu)化器會(huì)自動(dòng)將with as短語所獲取的數(shù)據(jù)放入一個(gè)temp表里,如果只是被調(diào)用一次,則不會(huì)。而提示materialize則是強(qiáng)制將with as短語里的數(shù)據(jù)放入一個(gè)全局臨時(shí)表里。很多查詢通過這種方法都可以提高速度。

with
sql1 as (select to_char(a) s_name from test_tempa),
sql2 as (select to_char(b) s_name from test_tempb where not exists (select s_name from sql1 where rownum=1))
select * from sql1
union all
select * from sql2
union all
select ‘no records’ from dual
where not exists (select s_name from sql1 where rownum=1)
and not exists (select s_name from sql2 where rownum=1);

WITH語句的優(yōu)點(diǎn):

(1). SQL可讀性增強(qiáng)。比如對于特定with子查詢?nèi)€(gè)有意義的名字等。

(2)、with子查詢只執(zhí)行一次,將結(jié)果存儲(chǔ)在用戶臨時(shí)表空間中,可以引用多次,增強(qiáng)性能。

舉例:在進(jìn)行導(dǎo)入EXCEL的過程中,有時(shí)候,需要將數(shù)據(jù)存儲(chǔ)在臨時(shí)表中,當(dāng)下一次在進(jìn)行導(dǎo)入的時(shí)候,進(jìn)行清除臨時(shí)表的數(shù)據(jù),但是這時(shí)候,有時(shí)候發(fā)生并發(fā)問題的話,兩個(gè)用戶可能會(huì)分別操作對方的數(shù)據(jù),所以,可能造成混亂,但是可以使用WITH函數(shù)和UNION語句拼接一個(gè)SQL語句,存儲(chǔ)在SESSION中,當(dāng)需要導(dǎo)出錯(cuò)誤信息的時(shí)候,可以使用該語句構(gòu)造數(shù)據(jù)。


分享到:
標(biāo)簽:SQL語句 withas該怎么用
用戶無頭像

網(wǎng)友整理

注冊時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定