久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

SQL - 在一張表中聯合所有用戶

SQL - Union All Users in One Table(SQL - 在一張表中聯合所有用戶)
本文介紹了SQL - 在一張表中聯合所有用戶的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

限時送ChatGPT賬號..

表:流行

<前>用戶名 朋友名————————————約翰·莎拉菲利普·烏蘇拉約翰·瑪麗約翰杰里米菲利普·布洛克汗萊米

我想要帶查詢的列表;

<前>約翰·菲利普·汗——————————————————莎拉·烏蘇拉·萊米嫁給布洛克 -NULL-杰里米 -NULL- -NULL-

我有 100 多個用戶名...幫助我使用 SQL 查詢 (MSSQL) 列出

解決方案

如果您有100+ 個用戶名",您會希望這是動態的,這樣您就不必為每個用戶名鍵入特定的 CASE 語句.

此外,每次向表中添加新用戶名時,您都不想更新腳本.

以下腳本將動態檢索所有不同的用戶名,并為他們創建一列,其中包含所有朋友的行.

 DECLARE @cols AS NVARCHAR(MAX), @query AS NVARCHAR(MAX);SET @cols = STUFF((SELECT distinct ',MAX(CASE WHEN UserName = '''+ p.UserName + ''' THEN FriendName END) AS '+ QUOTENAME(p.UserName) FROM 熱門 pFOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)'),1,1,'')SET @query = 'SELECT' + @cols + ' FROM(選擇用戶名,朋友名,ROW_NUMBER() OVER (PARTITION BY UserName ORDER BY FriendName) AS RowNum來自按用戶名、朋友名的熱門群組) XGROUP BY RowNum'執行(@查詢);

我上面的輸出如下所示;

╔========╦======╦========╗║ 約翰 ║ 汗 ║ 菲利普 ║╠========╬======╬========╣║ 杰里米 ║ 萊米 ║ 布洛克 ║║ 結婚 ║ NULL ║ 烏蘇拉 ║║ 莎拉 ║ NULL ║ NULL ║╚========╩======╩========╝

您應該能夠對整個表運行此程序并獲得所有可能的用戶名的結果,而無需鍵入單獨的 CASE 語句.

對于任何想要測試的人,這里是測試表和數據腳本;

 IF EXISTS ( SELECT *來自 INFORMATION_SCHEMA.TABLESWHERE TABLE_NAME = '流行'AND TABLE_SCHEMA = 'dbo'AND TABLE_TYPE = 'TABLE')刪除表 [dbo].[流行];走創建表 [dbo].[流行](用戶名 VARCHAR(20),朋友名 VARCHAR(20));走INSERT INTO [dbo].[Popular] (UserName,FriendName) VALUES('約翰','莎拉'),('菲利普','烏蘇拉'),('約翰','瑪麗'),('約翰','杰里米'),('菲利普','布洛克'),('汗','萊米');

Table : Popular

UserName   FriendName
--------   ---------- 
John       Sarah
Philip     Ursula
John       Marry
John       Jeremy
Philip     Brock
Khan       Lemy

And I want list with query;

John       Philip       Khan
--------   ----------   --------
Sarah      Ursula       Lemy
Marry      Brock        -NULL-
Jeremy     -NULL-       -NULL-

I have 100+ Username... help me for to list with SQL Query (MSSQL)

解決方案

If you have "100+ UserNames" you will want this to be DYNAMIC so that you don't have to type out specific CASE statements for each UserName.

Also you won't want to have to update your script every time a new UserName is added to your table.

The below script will dynamically retrieve all distinct UserNames and create a column for them with rows for all their friends.

    DECLARE @cols AS NVARCHAR(MAX), @query AS NVARCHAR(MAX);

    SET @cols = STUFF((SELECT distinct ',MAX(CASE WHEN UserName = ''' 
                        + p.UserName + ''' THEN FriendName END) AS ' 
                        + QUOTENAME(p.UserName) FROM Popular p
                FOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)'),1,1,'')

    SET @query = 'SELECT ' + @cols + ' FROM 
                (SELECT UserName, FriendName
                    ,ROW_NUMBER() OVER (PARTITION BY UserName ORDER BY FriendName) AS RowNum
                    FROM Popular GROUP BY USERNAME, FRIENDNAME
                ) x
                GROUP BY RowNum'

    EXECUTE(@query);

My output from the above shows as the below;

╔════════╦══════╦════════╗
║  John  ║ Khan ║ Philip ║
╠════════╬══════╬════════╣
║ Jeremy ║ Lemy ║ Brock  ║
║ Marry  ║ NULL ║ Ursula ║
║ Sarah  ║ NULL ║ NULL   ║
╚════════╩══════╩════════╝

You should be able to run this against entire table and get results for all possible UserNames without having to type out individual CASE Statements.

For anyone wanting to test this, here is the test table and data script;

    IF EXISTS ( SELECT *
                FROM INFORMATION_SCHEMA.TABLES
                WHERE TABLE_NAME = 'Popular'
                AND TABLE_SCHEMA = 'dbo'
                AND TABLE_TYPE = 'TABLE')
    DROP TABLE [dbo].[Popular];
    GO

    CREATE TABLE [dbo].[Popular]
    (
    UserName VARCHAR(20),
    FriendName VARCHAR(20)
    );
    GO

    INSERT INTO [dbo].[Popular] (UserName,FriendName) VALUES
    ('John','Sarah'),
    ('Philip','Ursula'),
    ('John','Marry'),
    ('John','Jeremy'),
    ('Philip','Brock'),
    ('Khan','Lemy');

這篇關于SQL - 在一張表中聯合所有用戶的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

What SQL Server Datatype Should I Use To Store A Byte[](我應該使用什么 SQL Server 數據類型來存儲字節 [])
Interpreting type codes in sys.objects in SQL Server(解釋 SQL Server 中 sys.objects 中的類型代碼)
Typeorm Does not return all data(Typeorm 不返回所有數據)
Typeorm .loadRelationCountAndMap returns zeros(Typeorm .loadRelationCountAndMap 返回零)
How to convert #39;2016-07-01 01:12:22 PM#39; to #39;2016-07-01 13:12:22#39; hour format?(如何將“2016-07-01 01:12:22 PM轉換為“2016-07-01 13:12:22小時格式?)
MS SQL: Should ISDATE() Return quot;1quot; when Cannot Cast as Date?(MS SQL:ISDATE() 是否應該返回“1?什么時候不能投射為日期?)
主站蜘蛛池模板: 91久久精品日日躁夜夜躁国产 | 国产在线资源 | 香蕉视频1024 | 欧美日韩在线免费 | 久草成人 | 日本不卡一区二区三区 | 天天干亚洲 | 国产最新网址 | 日韩亚洲欧美一区 | 亚洲社区在线 | 99久久精品国产麻豆演员表 | 国产精品久久精品 | 欧美video | 超碰人人插 | 久草精品视频 | 综合色站导航 | 午夜爽爽爽男女免费观看影院 | 亚洲欧美综合精品久久成人 | 精品一区av | 亚洲一区国产精品 | 久久久99精品免费观看 | 成人在线播放 | 91精品国产综合久久福利软件 | 国产免费福利小视频 | 蜜臀久久99精品久久久久久宅男 | 国产色在线 | 91精品久久久久久久久 | 亚洲成人免费电影 | 日韩快播电影 | 久久久久亚洲国产| 亚洲国产精品一区二区三区 | 久久久久久久久99 | 男人天堂手机在线视频 | 精品国产一区二区三区久久狼黑人 | 中文字幕电影在线观看 | 亚洲成网站 | 国产精品完整版 | 中文字幕不卡 | 亚洲a一区 | 亚洲精品一区二区三区蜜桃久 | 黑人中文字幕一区二区三区 |