SQLServer中JSON文檔型數(shù)據(jù)的查詢問題解決
近日在項目中遇到一個問題: 如何在報表中統(tǒng)計JSON格式存儲的數(shù)據(jù)?
例如有個調(diào)查問卷記錄表,記錄每個問題的答案。 其結(jié)構(gòu)示意如下(橫表設(shè)計)
Id | user | date | Q1_Answer | Q2_Answer | Q3_Answer |
行Id | 答題用戶 | 答題日期 | 問題一結(jié)果 | 問題二結(jié)果 | 問題三結(jié)果 |
在[Q1_Answer]、[Q2_Answer]、[Q3_Answer]中記錄的數(shù)據(jù)格式是JSON文檔內(nèi)容,因為是選項值,而且考慮到可能有多選, 所以存儲的格式如下:
1 [ {"code":"a", "desc":"Jan."}, {"code":"b", "desc":"Feb."} ]
其中 code 表示選項, desc 表示選項的文字描述。
現(xiàn)在,用戶想用PowerBI 來實現(xiàn)對結(jié)果的統(tǒng)計。有如下幾個問題:
- 在Power BI中,無法直接從JSON數(shù)據(jù)中讀取到選項值
- 如果是多選,又該如何處理。
比較適合分析的數(shù)據(jù)結(jié)構(gòu)應(yīng)該長這樣:
行Id | 答題用戶 | 答題日期 | 問題編號 | 用戶選項 | 選項文字 |
1 | user1 | 2021-6-26 | Q1 | A | Jan. |
2 | user1 | 2021-6-26 | Q2 | A | Mon. |
3 | user1 | 2021-6-26 | Q2 | B | Tue. |
4 | user1 | 2021-6-26 | Q3 | A | Swimming |
6 | user2 | 2021-6-26 | Q1 | B | Feb. |
7 | user2 | 2021-6-26 | Q2 | ... | ... |
注意,上述Q2用戶填了2個選項。 本身問卷設(shè)定就是支持多選的。 用JSON文檔結(jié)構(gòu)保存數(shù)據(jù), 主要是為了方便采集和數(shù)據(jù)存取。因此要額外做些數(shù)據(jù)處理, 使采集的數(shù)據(jù)便于統(tǒng)計。
筆者經(jīng)過一些調(diào)查, 發(fā)現(xiàn)可以結(jié)合使用UNPIVOT和OPENJSON方法來達到理想的效果。 具體過程如下:
準(zhǔn)備表格和初始化數(shù)據(jù)
-- 1 create table Create Table T_Questionaire(id int identity(1,1) primary key, username varchar(100), t1 nvarchar(500),t2 nvarchar(500),t3 nvarchar(500), dt datetime) -- 2 init data Insert into T_Questionaire( username, t1, t2, t3, dt) values ('John' , '[{"code":"a", "desc":"Monday"}]', '[{"code":"a", "desc":"Jan."}]', '[{"code":"b", "desc":"2021"}]' ,getdate()) , ('Alice' , '[{"code":"b", "desc":"Tuesday"}]', '[{"code":"a", "desc":"Jan."}, {"code":"b", "desc":"Feb."}]', '[{"code":"a", "desc":"2020"},{"code":"b", "desc":"2021"}]' ,getdate())
數(shù)據(jù)內(nèi)容:
創(chuàng)建轉(zhuǎn)換視圖:
Create or alter view V_VerticalQuestionaire as with pt as ( select a.username, a.T, a.answers, a.dt from dbo.T_Questionaire a unpivot ( answers for T in (t1,t2,t3 )) a) select pt.username, pt.dt, pt.T , aw.code, aw.[desc] from pt cross apply openjson(answers) WITH (code NVARCHAR(100) '$.code', [desc] NVARCHAR(100) '$.desc') aw
查詢結(jié)果如下:
總結(jié)下解決的思路:
1 先用unpivot將列行轉(zhuǎn)換, 使橫表記錄變成縱表記錄
2 使用openjson 將json數(shù)據(jù)轉(zhuǎn)換為集合數(shù)據(jù), 然后使用cross apply 將集合展開
好了,到此這篇關(guān)于SQLServer中JSON文檔型數(shù)據(jù)的查詢問題解決的文章就介紹到這了,更多相關(guān)SQLServer中JSON數(shù)據(jù)查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SQL?Server?2022?AlwaysOn新特性之包含可用性組詳解
這篇文章主要介紹了SQL?Server?2022?AlwaysOn新特性之包含可用性組介紹,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04使用SqlServer CTE遞歸查詢處理樹、圖和層次結(jié)構(gòu)
遞歸CTE是SQL SERVER 2005中重要的增強之一。一般我們在處理樹,圖和層次結(jié)構(gòu)的問題時需要用到遞歸查詢。本文給大家詳解使用sqlserver cte遞歸查詢出來樹、圖和層次結(jié)構(gòu),本文介紹的非常詳細,感興趣的朋友一起看看吧2015-11-11SQL Server 數(shù)據(jù)頁緩沖區(qū)的內(nèi)存瓶頸分析
數(shù)據(jù)頁緩存是SQL Server的內(nèi)存使用主要的方面,也是占用量最大的部分。在一個穩(wěn)定的DB Server上,這部分內(nèi)存使用會相對較穩(wěn)定2012-08-08SQLServer數(shù)據(jù)庫處于恢復(fù)掛起狀態(tài)的解決辦法
這篇文章主要介紹了SQLServer數(shù)據(jù)庫處于恢復(fù)掛起狀態(tài)的解決辦法 ,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-08-08SQL Server數(shù)據(jù)庫備份加密的方法詳解
在數(shù)據(jù)即資產(chǎn)的今天,保護數(shù)據(jù)庫備份免受未授權(quán)訪問是至關(guān)重要的,SQL Server提供了強大的安全特性,包括對數(shù)據(jù)庫備份進行加密的能力,本文將深入探討如何在SQL Server中實現(xiàn)數(shù)據(jù)庫的自定義數(shù)據(jù)備份加密,需要的朋友可以參考下2024-08-08