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

主頁 > 知識庫 > SQL Server 總結復習(一)

SQL Server 總結復習(一)

熱門標簽:威海智能語音外呼系統 北京辦理400電話多少 西安青牛防封電銷卡 溫州語音外呼系統代理 重慶防封電銷機器人供應商 400電話申請需要開戶費嗎 智能語音外呼系統哪個牌子好 南京電銷外呼系統運營商 山西語音外呼系統價格
1. TVP, 表變量,臨時表,CTE 的區別
TVP和臨時表都是可以索引的,總是存在tempdb中,會增加系統數據庫開銷,而表變量和CTE只有在內存溢出時才會被寫入tempdb中。對于數據量大,并且反復使用,反復進行查詢關聯的,建議使用臨時表或TVP,數據量小,使用表變量或CTE比較合適
2. sql_variant 萬能類型
可以存放所有數據類型,相當于C#中的object數據類型
3. datetime, datetime2, datetimeoffset
datetime 時間有效期較小,在1753-1-1 之前就不能使用了,精度為毫秒級別,而datetime2 數據范圍相當于C#中的datetime ,精度達到了秒后面小數點后7位,datetimeoffset則是考慮是時區的日期類型
4. MERGE的用法
語法很簡單就不說了,主要是處理兩張表某些字段對比后的操作,需注意 when not matched (by target) 與 when not matched by source的區別,前者是是針對對比后目標表不存在的記錄,可以選擇insert操作,而后者則是針對對比后目標表多出來的記錄,可以選擇delete或update操作
5. rowversion 類型
代替以前的timestamp,時間戳,8字節二進制值,常用來進行解決并發操作的問題
6. Sysdatetime()
返回datetime2類型,精度比datetime高
7. with cube , with rollup , grouping sets 運算符
都可與group by 后連用,with cube 表示匯總所有級別的組合,with rollup 則是按級別匯總,從下面的代碼可以詳細看出區別。注意,匯總行,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 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 總結復習(一)》,本文關鍵詞  SQL,Server,總結,復習,一,SQL,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server 總結復習(一)》相關的同類信息!
  • 本頁收集關于SQL Server 總結復習(一)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    ww久久中文字幕| 久久99精品久久久久婷婷| 久久精品这里都是精品| 日韩亚洲欧美成人一区| 久久理论电影网| 国产精品久久久久久妇女6080 | 亚洲色图一区二区三区| 亚洲精品国产高清久久伦理二区| 国产欧美视频一区二区| 久久精品一区四区| 久久久久久久国产精品影院| 久久精品视频免费| 中文字幕中文在线不卡住| 中文字幕精品—区二区四季| 欧美成人精精品一区二区频| 亚洲一区二区三区四区在线| 国产成人精品在线看| 欧美日韩三级一区| 午夜精品视频一区| 粉嫩在线一区二区三区视频| 欧美日韩午夜在线| 亚洲欧美日韩国产成人精品影院| 有坂深雪av一区二区精品| 日韩精品成人一区二区三区| 国产凹凸在线观看一区二区| 99久久精品国产一区| 欧美精品免费视频| 一区二区三区中文字幕精品精品 | 天天av天天翘天天综合网色鬼国产| 久久99精品久久久久| 欧美丰满一区二区免费视频| 日日夜夜免费精品| 色激情天天射综合网| 亚洲r级在线视频| 欧美成人精品二区三区99精品| 国产清纯白嫩初高生在线观看91| 88在线观看91蜜桃国自产| 亚洲一区二区综合| 91在线porny国产在线看| 久久一留热品黄| 国产精品一区二区你懂的| 日韩亚洲欧美一区| 国产一区中文字幕| 欧美日韩一区二区三区四区| 亚洲精品高清视频在线观看| 色成人在线视频| 国产精品久久国产精麻豆99网站| 国产美女久久久久| 国产成人在线色| 亚洲欧洲色图综合| 欧美在线你懂得| 国产精品色哟哟| 99久久久久久| 亚洲无人区一区| 中文字幕av资源一区| 91视频免费播放| 蜜臀av性久久久久蜜臀av麻豆| 综合色中文字幕| 欧美久久久久中文字幕| 国产精品伊人色| 国产日韩欧美一区二区三区综合| 中文字幕成人网| 亚洲男同1069视频| 日本一区二区三区电影| 欧洲精品在线观看| 99久久777色| 国产凹凸在线观看一区二区| 亚洲高清视频中文字幕| 亚洲午夜av在线| 日本va欧美va精品发布| 亚洲一区二区3| 一区二区三区四区不卡视频| 久久午夜国产精品| 综合av第一页| 中文字幕乱码亚洲精品一区| 99久久精品情趣| 精品国产三级电影在线观看| 中文字幕中文字幕一区| 亚洲444eee在线观看| 亚洲一区免费视频| 一区二区久久久久| 日韩国产在线一| 香蕉久久夜色精品国产使用方法 | 欧美军同video69gay| 精品国产乱码久久久久久1区2区| 久久久精品免费观看| 亚洲国产精品久久久久秋霞影院| 国产精品资源站在线| 成人午夜激情影院| 欧美影院精品一区| 日韩欧美专区在线| 国产精品私人自拍| 91黄色激情网站| 日韩视频免费直播| 精品日韩欧美在线| 中文字幕亚洲一区二区va在线| 欧美国产综合色视频| 亚洲综合色成人| 强制捆绑调教一区二区| 久久精品国产久精国产爱| 国产成人8x视频一区二区| 成人白浆超碰人人人人| 在线观看网站黄不卡| 国产精品久久久久毛片软件| 日韩伦理av电影| 免费在线看成人av| 99国内精品久久| 色诱亚洲精品久久久久久| 日本不卡中文字幕| 欧美一区二区三区免费| 国产三级精品在线| 亚洲综合久久久| 视频一区二区中文字幕| 欧美精品v国产精品v日韩精品| 一级做a爱片久久| 热久久一区二区| 久久综合久久综合久久| 国产日韩欧美一区二区三区乱码| 久久精品国产一区二区三| 欧美一区二区精品| 亚洲最大成人网4388xx| 久久福利资源站| 欧美性色黄大片| 日韩欧美中文字幕公布| 亚洲永久精品国产| 蜜臀久久99精品久久久久宅男| 国产亚洲欧洲一区高清在线观看| 色综合色综合色综合| 日韩中文字幕麻豆| 日韩精品一区二区三区视频在线观看| 久久精品国产一区二区三区免费看 | 国产不卡在线视频| 亚洲国产精品久久艾草纯爱| 精品成人一区二区| 国产+成+人+亚洲欧洲自线| 日韩专区中文字幕一区二区| 欧美三区在线观看| 日韩成人免费看| 亚洲一区二区综合| 亚洲人成影院在线观看| 日本怡春院一区二区| 亚洲视频网在线直播| 欧美国产欧美综合| 国产精品人成在线观看免费| 欧美一区二区久久| 精品福利视频一区二区三区| 日韩一区二区三区三四区视频在线观看| 欧美人妇做爰xxxⅹ性高电影 | 日韩精品一区二| 99热99精品| 婷婷丁香激情综合| 国产精品网站在线观看| 成人黄页在线观看| 亚洲在线免费播放| 日韩精品一区二| 欧美精选一区二区| 日本丶国产丶欧美色综合| 成人激情免费网站| 国产精品一区二区在线看| 国产亚洲视频系列| 久久久久九九视频| 亚洲精品一区二区三区精华液| 欧美肥妇毛茸茸| 亚洲精品一区二区三区香蕉| 欧美在线一二三四区| 欧美亚洲免费在线一区| 91网站最新地址| 在线欧美日韩精品| av一本久道久久综合久久鬼色| 美女视频黄免费的久久| 免费亚洲电影在线| 日本欧美久久久久免费播放网| 亚洲一区二区av在线| 五月婷婷久久丁香| 一区二区三区视频在线看| 国产99久久久国产精品潘金 | 国产一区二区福利| 蜜桃av噜噜一区二区三区小说| 久久电影网站中文字幕| 狠狠狠色丁香婷婷综合激情| 日韩电影在线一区二区| 一区二区免费视频| 国产91对白在线观看九色| 成人a区在线观看| 欧美日本乱大交xxxxx| 日韩欧美国产综合一区| 国产日韩v精品一区二区| 麻豆成人av在线| 精品一区二区久久久| 国产成人鲁色资源国产91色综| 欧美一区三区二区| 日本成人在线看| 国产不卡在线视频| 日韩欧美国产一二三区| 精品欧美乱码久久久久久1区2区| 欧美精品一区二区不卡| 一区二区三区中文字幕精品精品 | 国产精品高潮呻吟| 美国一区二区三区在线播放| 99精品欧美一区二区三区小说|