国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

SQL處理多級分類,查詢結果呈樹形結構

2020-07-25 13:13:58
字體:
來源:轉載
供稿:網友
這樣處理的弊端是:如果數據量大,子分類很多,達到4級以上,這方法處理極端占用數據庫連接池
對性能影響很大。

如果用SQL下面的CTE遞歸處理的話,一次性就能把結果給查詢出來,而且性能很不錯
比用程序處理(數據量很大的情況),臨時表性能更好,更方便
復制代碼 代碼如下:

with area as(
select *,id px,cast(id as nvarchar(4000)) px2 from region where parentid=0
union all
select a.*,b.px,b.px2+ltrim(a.region_id) from region a join area b on a.parentid=b.id
)select * from area order by px,px2


可以查詢出結果―-所有分類及相應分類下子分類
id title parentid
1 廣東省 0
2 廣州 1
3 白云區 2
4 深圳 1
5 湖南省 0
6 長沙 5
7 株洲 5
復制代碼 代碼如下:

with area as(
select * from region where parentid=1
union all
select a.* from region a join area b on a.parentid=b.id
)select * from area

可以查詢出結果―-指定分類及相應分類下子分類
id title parentid
1 廣東省 0
2 廣州 1
3 白云區 2


性能分析:
對于一個3500條地區記錄的數據表,其中有省,市,縣3級
查詢用時要1秒,視覺上感覺有點點慢,但不影響
數據量不大的分類,使用絕對無壓力
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 四平市| 卢龙县| 金寨县| 朔州市| 兴安盟| 南丹县| 南城县| 青冈县| 炎陵县| 项城市| 忻城县| 卓尼县| 宜宾市| 子长县| 扶沟县| 南投县| 姚安县| 白银市| 随州市| 邳州市| 莒南县| 辛集市| 扶余县| 濮阳市| 陆良县| 平顶山市| 高密市| 临海市| 临漳县| 汉川市| 太湖县| 孙吴县| 马山县| 德州市| 澄迈县| 天等县| 海安县| 江城| 新邵县| 五台县| 普兰县|