电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

SQLServer實(shí)現(xiàn)Ungroup操作的示例代碼

瀏覽:172日期:2023-09-25 20:57:30
目錄概要代碼和實(shí)現(xiàn)代碼和實(shí)現(xiàn)基本思路代碼第1輪查詢第2輪查詢第3輪查詢第4輪查詢代碼改進(jìn)附錄概要

我們經(jīng)常在SQL Server中使用group by語(yǔ)句配合聚合函數(shù),對(duì)已有的數(shù)據(jù)進(jìn)行分組統(tǒng)計(jì)。本文主要介紹一種分組的逆向操作,通過(guò)一個(gè)遞歸公式,實(shí)現(xiàn)ungroup操作。

代碼和實(shí)現(xiàn)

我們看一個(gè)例子,輸入數(shù)據(jù)如下,我們有一張產(chǎn)品表,該表顯示了產(chǎn)品的數(shù)量。

要求實(shí)現(xiàn)Ungroup操作,最后輸出數(shù)據(jù)如下:

代碼和實(shí)現(xiàn)基本思路

要想實(shí)現(xiàn)ungroup,顯然需要表格的自連接。自連接的次數(shù)取決于total_count的數(shù)量。

代碼

自連接操作過(guò)程中涉及大量的子查詢,為了便于代碼后期維護(hù),我們采用CTE。每次子查詢,total_count自動(dòng)減一,total_count小于0時(shí),直接過(guò)濾掉,該數(shù)據(jù)不再參與查詢。

第1輪查詢

獲取全部total_count 大于0的數(shù)據(jù),即全表數(shù)據(jù)。

with cte1 as (select * from products where total_count > 0),

輸出結(jié)果:

第2輪查詢

第2輪子查詢,以第1輪的輸出作為輸入,進(jìn)行表格自連接,total_count減1,過(guò)濾掉total_count小于0的產(chǎn)品。

with cte1 as (select * from products where total_count > 0),cte2 as (select * from (select cte1.id, cte1.name, (cte1.total_count -1) as total_count from cte1join products p1 on cte1.id = p1.id) t where t.total_count > 0)select * from cte2

輸出結(jié)果是:

和第1輪相比較,輸出結(jié)果中沒(méi)了Flashlight了,因?yàn)樗膖otal_count減1后為0,被過(guò)濾了。

第3輪查詢

第3輪子查詢,以第2輪的輸出作為輸入,進(jìn)行表格自連接,total_count減1,過(guò)濾掉total_count小于0的產(chǎn)品。

with cte1 as (select * from products where total_count > 0),cte2 as (select * from (select cte1.id, cte1.name, (cte1.total_count -1) as total_count from cte1join products p1 on cte1.id = p1.id) t where t.total_count > 0),cte3 as (select * from (select cte2.id, cte2.name, (cte2.total_count -1) as total_count from cte2join products p1 on cte2.id = p1.id) t where t.total_count > 0)select * from cte3

輸出結(jié)果如下:

第4輪查詢

第4輪子查詢,以第3輪的輸出作為輸入,進(jìn)行表格自連接,total_count減1,過(guò)濾掉total_count小于0的產(chǎn)品。

with cte1 as (select * from products where total_count > 0),cte2 as (select * from (select cte1.id, cte1.name, (cte1.total_count -1) as total_count from cte1join products p1 on cte1.id = p1.id) t where t.total_count > 0),cte3 as (select * from (select cte2.id, cte2.name, (cte2.total_count -1) as total_count from cte2join products p1 on cte2.id = p1.id) t where t.total_count > 0),cte4 as (select * from (select cte3.id, cte3.name, (cte3.total_count -1) as total_count from cte3join products p1 on cte3.id = p1.id) t where t.total_count > 0)select * from cte4

輸出結(jié)果:

下一次迭代,compass的total_count也將等于0,被過(guò)濾掉,查詢結(jié)果不會(huì)再有新的記錄,所以查詢結(jié)束。我們將cte1,cte2,cte3 和 cte4 合并,合并結(jié)果即是所求。

代碼改進(jìn)

顯然上述代碼過(guò)于冗長(zhǎng),如果產(chǎn)品數(shù)量很多,那子查詢的代碼也將大幅度增加。

事實(shí)上,從第2輪到第4輪的子查詢,代碼是非常相近的,對(duì)于這種情況,無(wú)論任何開發(fā)語(yǔ)言,我們都可以采用遞歸的方式進(jìn)行優(yōu)化處理。對(duì)于此類為題,遞歸公式如下:

with CTE as (initial query -- 初始查詢union all -- 查詢結(jié)果合并recursive query -- 遞歸部分,即在查詢中直接引用CTERecursive terminatation condition -- 遞歸終止條件)

初始查詢,就是我們的第1輪迭代。遞歸部分,就是我們所謂的相似代碼部分。

對(duì)于遞歸終止條件,默認(rèn)是如果沒(méi)有新的記錄參加遞歸,則遞歸終止。本例是按照業(yè)務(wù)邏輯,設(shè)置的終止條件,即total_count需要大于0,這樣也可以做到過(guò)濾到最后,不會(huì)再有新的記錄參與到遞歸中。

按照上述供述,得到的查詢代碼如下:

with cte as (select * from products where total_count > 0union allselect * from (select cte.id, cte.name, (cte.total_count -1) as total_count from ctejoin products p1 on cte.id = p1.id) t where t.total_count > 0)select id, name from cteorder by id, name

當(dāng)我們使用CTE時(shí)候,發(fā)現(xiàn)每次查詢的代碼類似,就可以考慮采用上述遞歸公式對(duì)代碼進(jìn)行優(yōu)化。找到初始查詢結(jié)果,在相似的代碼中找到遞歸部分以及遞歸終止條件。

附錄

建表和數(shù)據(jù)初始化代碼

if OBJECT_ID('products', 'U') is not null drop table productscreate table products (id int primary key identity(1,1),name nvarchar(50) not null,total_count int not null)insert into products (name, total_count) values ('Water Bottle', 3),('Tent', 2),('Flashlight', 1),('compass',4)

到此這篇關(guān)于SQLServer實(shí)現(xiàn)Ungroup操作的示例代碼的文章就介紹到這了,更多相關(guān)SQLServer Ungroup操作內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MsSQL 數(shù)據(jù)庫(kù)
主站蜘蛛池模板: 碳纤维复合材料制品生产定制工厂订制厂家-凯夫拉凯芙拉碳纤维手机壳套-碳纤维雪茄盒外壳套-深圳市润大世纪新材料科技有限公司 | 湖州织里童装_女童男童中大童装_款式多尺码全_织里儿童网【官网】-嘉兴嘉乐网络科技有限公司 | 证券新闻,热播美式保罗1984第二部_腾讯1080p-仁爱影院 | 活性炭-蜂窝-椰壳-柱状-粉状活性炭-河南唐达净水材料有限公司 | 大立教育官网-一级建造师培训-二级建造师培训-造价工程师-安全工程师-监理工程师考试培训 | 冷却塔风机厂家_静音冷却塔风机_冷却塔电机维修更换维修-广东特菱节能空调设备有限公司 | 土壤水分自动监测站-SM150便携式土壤水分仪-铭奥仪器 | 南京技嘉环保科技有限公司-杀菌除臭剂|污水|垃圾|厕所|橡胶厂|化工厂|铸造厂除臭剂 | 预制围墙_工程预制围墙_天津市瑞通建筑材料有限公司 | 伊卡洛斯软装首页-电动窗帘,别墅窗帘,定制窗帘,江浙沪1000+别墅窗帘案例 | 楼承板-钢筋楼承板-闭口楼承板-无锡优贝斯楼承板厂 | 成都珞石机械 - 模温机、油温机、油加热器生产厂家 | 金环宇|金环宇电线|金环宇电缆|金环宇电线电缆|深圳市金环宇电线电缆有限公司|金环宇电缆集团 | 沈阳激光机-沈阳喷码机-沈阳光纤激光打标机-沈阳co2激光打标机 | 除湿机|工业除湿机|抽湿器|大型地下室车间仓库吊顶防爆除湿机|抽湿烘干房|新风除湿机|调温/降温除湿机|恒温恒湿机|加湿机-杭州川田电器有限公司 | 碳刷_刷握_集电环_恒压簧_电刷厂家-上海丹臻机电科技有限公司 | 扫地车厂家-山西洗地机-太原电动扫地车「大同朔州吕梁晋中忻州长治晋城洗地机」山西锦力环保科技有限公司 | 北京发电车出租-发电机租赁公司-柴油发电机厂家 - 北京明旺盛安机电设备有限公司 | 干法制粒机_智能干法制粒机_张家港市开创机械制造有限公司 | ISO9001认证咨询_iso9001企业认证代理机构_14001|18001|16949|50430认证-艾世欧认证网 | 分子精馏/精馏设备生产厂家-分子蒸馏工艺实验-新诺舜尧(天津)化工设备有限公司 | 山东螺杆空压机,烟台空压机,烟台开山空压机-烟台开山机电设备有限公司 | 冲锋衣滑雪服厂家-冲锋衣定制工厂-滑雪服加工厂-广东睿牛户外(S-GERT) | 滁州高低温冲击试验箱厂家_安徽高低温试验箱价格|安徽希尔伯特 | 高铝砖-高铝耐火球-高铝耐火砖生产厂家-价格【荣盛耐材】 | 福州时代广告制作装饰有限公司-福州广告公司广告牌制作,福州展厅文化墙广告设计, | 安平县鑫川金属丝网制品有限公司,声屏障,高速声屏障,百叶孔声屏障,大弧形声屏障,凹凸穿孔声屏障,铁路声屏障,顶部弧形声屏障,玻璃钢吸音板 | 维泰克Veertek-锂电池微短路检测_锂电池腐蚀检测_锂电池漏液检测 | 企业管理培训,企业培训公开课,企业内训课程,企业培训师 - 名课堂企业管理培训网 | 爆炸冲击传感器-无线遥测传感器-航天星百科| 【灵硕展览集团】展台展会设计_展览会展台搭建_展览展示设计一站式服务公司 | 正压密封性测试仪-静态发色仪-导丝头柔软性测试仪-济南恒品机电技术有限公司 | 橡胶接头_橡胶软接头_套管伸缩器_管道伸缩器厂家-巩义市远大供水材料有限公司 | 动力配电箱-不锈钢配电箱-高压开关柜-重庆宇轩机电设备有限公司 聚天冬氨酸,亚氨基二琥珀酸四钠,PASP,IDS - 远联化工 | 上海电子秤厂家,电子秤厂家价格,上海吊秤厂家,吊秤供应价格-上海佳宜电子科技有限公司 | 贵州水玻璃_-贵阳花溪闽兴水玻璃厂 | 千斤顶,液压千斤顶-力良企业,专业的液压千斤顶制造商,shliliang.com | 神马影院-实时更新秒播| 北京包装设计_标志设计公司_包装设计公司-北京思逸品牌设计 | 空气能采暖,热泵烘干机,空气源热水机组|设备|厂家,东莞高温热泵_正旭新能源 | 立式_复合式_壁挂式智能化电伴热洗眼器-上海达傲洗眼器生产厂家 理化生实验室设备,吊装实验室设备,顶装实验室设备,实验室成套设备厂家,校园功能室设备,智慧书法教室方案 - 东莞市惠森教学设备有限公司 |