婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > SQL Server 2008 新特性 總結復習(一)

SQL Server 2008 新特性 總結復習(一)

熱門標簽:浙江地圖標注 創(chuàng)業(yè)電銷機器人 沈陽智能外呼系統(tǒng)代理 滄州營銷外呼系統(tǒng)軟件 舞鋼市地圖標注app 松原導航地圖標注 九鹿林外呼系統(tǒng)怎么收費 電銷機器人虛擬號碼 海南自動外呼系統(tǒng)價格
1. TVP, 表變量,臨時表,CTE 的區(qū)別
TVP和臨時表都是可以索引的,總是存在tempdb中,會增加系統(tǒng)數據庫開銷,而表變量和CTE只有在內存溢出時才會被寫入tempdb中。對于數據量大,并且反復使用,反復進行查詢關聯的,建議使用臨時表或TVP,數據量小,使用表變量或CTE比較合適

2. sql_variant 萬能類型
可以存放所有數據類型,相當于C#中的object數據類型

3. datetime, datetime2, datetimeoffset
datetime 時間有效期較小,在1753-1-1 之前就不能使用了,精度為毫秒級別,而datetime2 數據范圍相當于C#中的datetime ,精度達到了秒后面小數點后7位,datetimeoffset則是考慮是時區(qū)的日期類型

4. MERGE的用法
語法很簡單就不說了,主要是處理兩張表某些字段對比后的操作,需注意 when not matched (by target) 與 when not matched by source的區(qū)別,前者是是針對對比后目標表不存在的記錄,可以選擇insert操作,而后者則是針對對比后目標表多出來的記錄,可以選擇delete或update操作
5. rowversion 類型
代替以前的timestamp,時間戳,8字節(jié)二進制值,常用來進行解決并發(fā)操作的問題

6. Sysdatetime()
返回datetime2類型,精度比datetime高

7. with cube , with rollup , grouping sets 運算符
都可與group by 后連用,with cube 表示匯總所有級別的組合,with rollup 則是按級別匯總,從下面的代碼可以詳細看出區(qū)別。注意,匯總行,null可以看成所有值
而grouping sets運算符,則僅返回每個分組頂級匯總行,在查詢匯總行中 可使用grouping(字段名) = 1來判斷,該運算符可和rollup, cube連用,表示按照grouping by sets和按照rollup/cube處理的結果集union all
示例代碼如下:
復制代碼 代碼如下:

With cube, With rollup
--示例代碼
declare @t table(goodsname VARCHAR(max) ,sku1name VARCHAR(max) , sku2name VARCHAR(max), qty INT)
insert @t select '凡客TX','紅色','S',1
insert @t select '凡客TX','黑色','S',2
insert @t select '凡客TX','白色','L',3
insert @t select '京東村山','白色','L',4
insert @t select '京東村山','紅色','S',5
insert @t select '京東村山','黑色','L',6
insert @t select '亞馬遜拖鞋','白色','L',7
insert @t select '亞馬遜拖鞋','紅色','S',8
SELECT * FROM @t
select goodsname,sku1name,sku2name,sum(qty) sumqty
from @t
group by goodsname,sku1name,sku2name with rollup
ORDER BY goodsname,sku1name,sku2name

select goodsname,sku1name,sku2name,sum(qty) sumqty
from @t
group by goodsname,sku1name,sku2name with cube
ORDER BY goodsname,sku1name,sku2name
-----------------------
declare @t table(goodsname VARCHAR(max) ,sku1name VARCHAR(max) , sku2name VARCHAR(max), qty INT)
insert @t select '凡客TX','紅色','S',1
insert @t select '凡客TX','黑色','S',2
insert @t select '凡客TX','白色','L',3
insert @t select '京東村山','白色','L',4
insert @t select '京東村山','紅色','S',5
insert @t select '京東村山','黑色','L',6
insert @t select '亞馬遜拖鞋','白色','L',7
insert @t select '亞馬遜拖鞋','紅色','S',8

--GROUPING SETS 運算符
SELECT goodsname,sku1name,sku2name, SUM(qty) FROM @t GROUP BY GROUPING SETS(goodsname,sku1name,sku2name)
SELECT goodsname, sku1name, sku2name ,SUM(qty) FROM @t
GROUP BY GROUPING SETS(goodsname), ROLLUP(sku1name,sku2name)
ORDER BY goodsname,sku1name,sku2name
SELECT goodsname, sku1name, sku2name ,SUM(qty) FROM @t
GROUP BY ROLLUP(goodsname,sku1name,sku2name)
ORDER BY goodsname,sku1name,sku2name
SELECT CASE WHEN GROUPING(goodsname) = 1 THEN '[ALL]' ELSE goodsname END goodsname,
CASE WHEN GROUPING(sku1name) = 1 THEN '[ALL]' ELSE sku1name END sku1name,
CASE WHEN GROUPING(sku2name) = 1 THEN '[ALL]' ELSE sku2name END sku2name ,SUM(qty) FROM @t
GROUP BY GROUPING SETS(goodsname), ROLLUP(sku1name,sku2name)
ORDER BY goodsname,sku1name,sku2name

8. 一些快捷的語法 例如 Declare @id int = 0

雖然有時很快捷,但DBA不建議這樣使用,Declare @id = select top 1 id from 表名,建議聲明和查表賦值分開

9. 公用表達式 CTE

特點:可嵌套使用,代替聯接表中的子查詢,結構層次更加清晰,也可用來遞歸查詢,另外通過巧妙的常量列控制遞歸層次

示例代碼如下:
復制代碼 代碼如下:

使用CTE

--公用表達式CTE Common table expression

--用CTE實現遞歸算法

CREATE TABLE EMPLOYEETREE(
EMPLOYEE INT PRIMARY KEY,
employeename nvarchar(50),
reportsto int
)

insert into EMPLOYEETREE values(1,'Richard',null)
insert into EMPLOYEETREE values(2,'Stephen',1)
insert into EMPLOYEETREE values(3,'Clemens',2)
insert into EMPLOYEETREE values(4,'Malek',2)
insert into EMPLOYEETREE values(5,'Goksin',4)
insert into EMPLOYEETREE values(6,'Kimberly',1)
insert into EMPLOYEETREE values(7,'Ramesh',5)

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

--確定哪些員工向Stephen報告的遞歸查詢
with employeeTemp as
(
select EMPLOYEE, employeename, reportsto from EMPLOYEETREE where EMPLOYEE = 2
union all
select a.EMPLOYEE, a.employeename, a.reportsto from EMPLOYEETREE as a
inner join employeeTemp as b on a.reportsto = b.EMPLOYEE
)
select * from employeeTemp where EMPLOYEE > 2 --option(maxrecursion 2)


--不報錯設置級聯關聯遞歸
with employeeTemp as
(
select EMPLOYEE, employeename, reportsto,0 as sublevel from EMPLOYEETREE where EMPLOYEE = 2
union all
select a.EMPLOYEE, a.employeename, a.reportsto,sublevel+1 from EMPLOYEETREE as a
inner join employeeTemp as b on a.reportsto = b.EMPLOYEE
)
select * from employeeTemp where EMPLOYEE > 2 and sublevel =2 --option(maxrecursion 2)

10. pivot 與 unpivot

前者用在行轉列,注意:必須用聚合函數與PIVOT一起使用,計算聚會時將不考慮出現在值列中的任何空值;一般情況下,可以用列上的子查詢來替換pivot語句,但是這樣做效率不高

后者用在列轉行,注意:如果某些列中有null值,將會被過濾掉,不產生新行;語法上For前指定的新列,對應原表指定列名中的值,For后指定的新列對應原表指定列名中的標題的值

兩者都有的共性:語法上最后必須要有別名;IN里面指定的列類型必須是一致的。

示例代碼如下:
復制代碼 代碼如下:

pivot與unpivot

--關于PIVOT的操作

CREATE TABLE #test
(
NAME VARCHAR(max),
SCORE INT
)

INSERT INTO #test VALUES ('張三','97')
INSERT INTO #test VALUES ('李四','28')
INSERT INTO #test VALUES ('王五','33')
INSERT INTO #test VALUES ('神人','78')

--NAME SCORE
--張三 97
--李四 28
--王五 33
--神人 78

--行轉列
SELECT --'成績單' AS SCORENAME ,
[張三], [李四], [王五]
FROM #test
PIVOT (AVG(SCORE) FOR NAME IN ([張三], [李四], [王五])) b


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

CREATE TABLE VendorEmployee(
VendorId INT,
Emp1Order INT,
Emp2Order INT,
Emp3Order INT,
Emp4Order INT,
Emp5Order INT,
)

GO

INSERT INTO VendorEmployee VALUES(1,4,3,5,4,4)
INSERT INTO VendorEmployee VALUES(2,4,1,5,5,5)
INSERT INTO VendorEmployee VALUES(3,4,3,5,4,4)
INSERT INTO VendorEmployee VALUES(4,4,2,5,4,4)
INSERT INTO VendorEmployee VALUES(5,5,1,5,5,5)

SELECT * FROM VendorEmployee

----------------
--列轉行

SELECT * FROM (
SELECT VendorId,[Emp1Order],[Emp2Order],[Emp3Order],[Emp4Order],[Emp5Order] FROM VendorEmployee) AS unpiv
UNPIVOT (orders FOR elyid IN ([Emp1Order],[Emp2Order],[Emp3Order],[Emp4Order],[Emp5Order])) AS child
ORDER BY elyid

SELECT * FROM VendorEmployee
UNPIVOT (orders FOR elyid IN ([Emp1Order],[Emp2Order],[Emp3Order],[Emp4Order],[Emp5Order])) AS child
ORDER BY elyid

SELECT * FROM VendorEmployee UNPIVOT ( ORDERS FOR [操作員名字] IN ([Emp1Order],[Emp2Order],[Emp3Order],[Emp4Order],[Emp5Order]))

標簽:西藏 日喀則 商洛 海口 寶雞 臺灣 公主嶺 咸寧

巨人網絡通訊聲明:本文標題《SQL Server 2008 新特性 總結復習(一)》,本文關鍵詞  SQL,Server,2008,新特性,新,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server 2008 新特性 總結復習(一)》相關的同類信息!
  • 本頁收集關于SQL Server 2008 新特性 總結復習(一)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品理论电影在线| 欧美日免费三级在线| 青青草97国产精品免费观看无弹窗版| 亚洲三级电影网站| 亚洲欧美在线视频| 亚洲精品日日夜夜| 亚洲国产精品麻豆| 免费看黄色91| 国产福利精品导航| 成人黄动漫网站免费app| 成人av影院在线| 一本到高清视频免费精品| 91成人免费电影| 欧美久久一区二区| 亚洲精品一区二区精华| 国产色综合一区| 一色屋精品亚洲香蕉网站| 中文字幕一区二| 亚洲成人在线观看视频| 免费成人美女在线观看.| 国产一区在线精品| 不卡大黄网站免费看| 欧美性一区二区| 欧美成人三级在线| 亚洲免费在线播放| 麻豆91精品视频| 不卡视频一二三四| 欧美一级免费观看| 日韩国产欧美一区二区三区| 2023国产精品| 亚洲综合在线观看视频| 日韩激情视频在线观看| 国产99精品视频| 欧美日韩国产首页| 中文字幕欧美三区| 婷婷久久综合九色国产成人| 国产成人av资源| 欧美久久一二区| 中文字幕精品—区二区四季| 午夜欧美2019年伦理| 国产麻豆精品久久一二三| 在线看日本不卡| 欧美激情中文不卡| 日本va欧美va欧美va精品| 成人精品国产福利| 日韩欧美一区二区不卡| 一区二区三区国产精华| 国产寡妇亲子伦一区二区| 欧美在线高清视频| 国产日韩av一区二区| 欧美96一区二区免费视频| 色欲综合视频天天天| 国产日本一区二区| 日韩精品1区2区3区| 99精品热视频| 国产精品网站在线| 国产精品正在播放| 欧美成人欧美edvon| 亚洲bt欧美bt精品777| 在线观看日韩毛片| 亚洲欧美aⅴ...| 97久久精品人人爽人人爽蜜臀| 久久久久久黄色| 寂寞少妇一区二区三区| 91精品国产色综合久久ai换脸| 亚洲在线免费播放| 在线精品视频免费播放| 亚洲激情成人在线| 欧美亚洲免费在线一区| 亚洲一区二区三区激情| 欧洲国内综合视频| 亚洲成av人综合在线观看| 欧美日本一区二区三区四区| 亚洲综合网站在线观看| 精品视频一区 二区 三区| 一片黄亚洲嫩模| 欧美日本一区二区| 日本午夜一区二区| 91精品国产色综合久久不卡蜜臀 | 中文字幕一区二区视频| 国产iv一区二区三区| 国产欧美一区二区在线观看| 成人在线综合网站| 一区二区中文字幕在线| 欧美在线免费观看亚洲| 日韩主播视频在线| 精品99一区二区| 成人免费视频播放| 一区二区久久久| 日韩精品一区二区在线| 成人午夜电影久久影院| 一区二区三区在线免费视频| 日韩一级黄色大片| 国产精品原创巨作av| 亚洲精品一卡二卡| 欧美一区二区三区四区五区| 国内精品免费在线观看| 亚洲特黄一级片| 欧美一二三区在线| 99国产欧美久久久精品| 午夜不卡av在线| 久久综合色8888| 一本一道久久a久久精品综合蜜臀| 午夜亚洲福利老司机| 国产午夜精品久久久久久免费视 | 成人精品高清在线| 亚洲成av人片www| 欧美激情中文字幕| 午夜激情一区二区| 91亚洲精华国产精华精华液| 性做久久久久久| 久久久久国产精品免费免费搜索| 9人人澡人人爽人人精品| 日本最新不卡在线| 一区二区在线电影| 久久五月婷婷丁香社区| 欧美日韩色一区| 国产精品91一区二区| 日韩精品高清不卡| 亚洲精品视频在线| 国产午夜亚洲精品午夜鲁丝片 | 欧美一区二区三区四区久久| 99这里都是精品| 国产一区91精品张津瑜| 午夜精品一区二区三区免费视频 | 99国产精品99久久久久久| 免费成人结看片| 午夜伦理一区二区| 一区二区三区在线观看视频| 中文字幕av免费专区久久| 欧美精品一区二区久久久| 精品视频一区二区不卡| 97久久久精品综合88久久| 丁香激情综合五月| 国产剧情一区在线| 国产一区不卡在线| 久久不见久久见免费视频7| 亚洲成人av福利| 亚洲一二三区在线观看| 一区二区三区影院| 亚洲一区在线免费观看| 亚洲精品中文在线观看| 亚洲麻豆国产自偷在线| 综合激情网...| 中文字幕亚洲精品在线观看| 中文字幕日韩一区| 一区视频在线播放| 一区二区在线看| 一区二区三区国产豹纹内裤在线| 亚洲美女屁股眼交3| 亚洲欧美乱综合| 亚洲国产美国国产综合一区二区| 一区二区三区高清不卡| 午夜av区久久| 久久精品国产久精国产爱| 国内精品伊人久久久久av一坑| 国产综合久久久久久久久久久久| 极品少妇xxxx偷拍精品少妇| 国产不卡视频一区二区三区| 丁香婷婷综合激情五月色| 成人手机电影网| 欧美综合色免费| 日韩欧美一级在线播放| 2023国产精品| 亚洲欧美国产毛片在线| 亚洲mv在线观看| 国内精品久久久久影院薰衣草| 国产成人在线视频免费播放| 色噜噜狠狠色综合中国| 日韩一区二区三区高清免费看看 | 在线免费观看成人短视频| 在线播放视频一区| 国产无人区一区二区三区| 亚洲欧美国产毛片在线| 秋霞电影网一区二区| 国产69精品一区二区亚洲孕妇| 972aa.com艺术欧美| 日韩一区二区三区视频| 国产精品蜜臀在线观看| 丝袜脚交一区二区| 国产盗摄精品一区二区三区在线| 色屁屁一区二区| 久久亚洲精精品中文字幕早川悠里| 国产精品久久久久久久久免费丝袜 | 3751色影院一区二区三区| 久久久国际精品| 亚洲123区在线观看| 成人午夜av在线| 制服丝袜亚洲精品中文字幕| 国产精品国产三级国产普通话三级| 午夜精品福利在线| 波多野结衣欧美| 久久综合一区二区| 五月激情六月综合| 一本一本大道香蕉久在线精品| 日韩女优视频免费观看| 一区二区欧美在线观看| 成人免费黄色在线| 久久久www成人免费毛片麻豆 | 欧美性生活影院|