如果您無法更改表格結構,則可以使用字符串拆分功能來創建可以使用的視圖。
創建和填充示例表(請保存我們這一步在你未來的問題):如果您使用的是SQL服務器2016
CREATE TABLE fruits
(
diffruits1 int,
diffruits2 varchar(100)
)
INSERT INTO fruits VALUES (1, 'apples=1000, bananas=2, oranges=1, blueberries=102')
,您可以使用內置的STRING_SPLIT
功能。對於較低版本,您需要先創建函數。
對於這個答案,我chosed使用基於傑夫MODEN的spliter功能,從阿龍貝特朗的文章Split strings the right way – or the next best way採取:
CREATE FUNCTION dbo.SplitStrings
(
@List NVARCHAR(MAX),
@Delimiter NVARCHAR(255)
)
RETURNS TABLE
WITH SCHEMABINDING AS
RETURN
WITH E1(N) AS (SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1
UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1
UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1),
E2(N) AS (SELECT 1 FROM E1 a, E1 b),
E4(N) AS (SELECT 1 FROM E2 a, E2 b),
E42(N) AS (SELECT 1 FROM E4 a, E2 b),
cteTally(N) AS (SELECT 0 UNION ALL SELECT TOP (DATALENGTH(ISNULL(@List,1)))
ROW_NUMBER() OVER (ORDER BY (SELECT NULL)) FROM E42),
cteStart(N1) AS (SELECT t.N+1 FROM cteTally t
WHERE (SUBSTRING(@List,t.N,1) = @Delimiter OR t.N = 0))
SELECT Item = SUBSTRING(@List, s.N1, ISNULL(NULLIF(CHARINDEX(@Delimiter,@List,s.N1),0)-s.N1,8000))
FROM cteStart s;
一旦你擁有了拆分字符串函數,你可以創建這樣的觀點:
CREATE VIEW vw_Splitted AS
SELECT diffruits1,
LTRIM(RTRIM(LEFT(Item, CHARINDEX('=', Item)-1))) As Name,
CAST(RIGHT(Item, LEN(Item) - CHARINDEX('=', Item)) As int) As Value
FROM fruits
CROSS APPLY dbo.SplitStrings(diffruits2, ',')
測試視圖:
SELECT *
FROM vw_Splitted
結果:
diffruits1 Name Value
1 apples 1000
1 bananas 2
1 oranges 1
1 blueberries 102
你可以看到現場演示上rextester:
你的問題不是clear.see參考知道如何提出一個完善的問題鏈接: https://spaghettidba.com/2015/04/24/how-to-post-at-sql-question-on-a-public-forum/ – TheGameiswar
您可以先對結構進行標準化,或者是給定結構且不能更改? –
將這樣的數據存儲在數據庫表中是* bug *。拆分不足以解析這些數據。在加載到數據庫之前,您應該解析數據並將其存儲在精心設計的表格中。所有你需要的是一個帶有'FruitName','Count'和ThatParentTableID列的獨立表格 –