wstcl 2024-09-21 12:36 采纳率: 0%
浏览 4

有这样一张表如果去掉重复

假设sql server有这样一张表,每个名字如果重复,只取第一个名字,怎么实现它,如果用distinct 姓名 发表文章不能得想要结果。

id 姓名 发表文章
1 张三 文章A
2 李四 文章B
3 张三 文章C
4 张三 文章D
5 李四 文章E
6 赵五 文章F

变成这样
id 姓名 发表文章
1 张三 文章A
2 李四 文章B
6 赵五 文章F

  • 写回答

1条回答 默认 最新

  • 一轮明月照丘壑 2024-09-21 12:37
    关注

    以下回复参考:皆我百晓生券券喵儿等免费微信小程序作答:

    你可以使用SQL中的窗口函数来达到这个目的。具体来说,你可以使用ROW_NUMBER()函数为每个姓名的重复项分配一个行号,然后只选择行号为1的记录。这样,对于每个重复的姓名,只有第一个出现的记录会被保留。

    以下是如何在SQL Server中实现这个操作的示例:

    WITH CTE AS (
        SELECT *,
               ROW_NUMBER() OVER(PARTITION BY 姓名 ORDER BY id) AS rn
        FROM 你的表名
    )
    SELECT id, 姓名, 发表文章
    FROM CTE
    WHERE rn = 1
    ORDER BY id;
    

    在这个查询中:

    • ROW_NUMBER()函数为每个姓名的重复项分配一个行号。这里按照id字段排序,但你可以根据需要选择其他排序方式。
    • PARTITION BY 姓名确保行号是在每个姓名的分组内独立分配的。
    • 在外部查询中,我们只选择行号为1的记录,这样就可以得到每个重复姓名只出现一次的结果。

    记得将你的表名替换为你的实际表名。执行这个查询后,你将得到你所期望的结果。

    评论

报告相同问题?

问题事件

  • 创建了问题 9月21日

悬赏问题

  • ¥15 如何在vue.config.js中读取到public文件夹下window.APP_CONFIG.API_BASE_URL的值
  • ¥50 浦育平台scratch图形化编程
  • ¥20 求这个的原理图 只要原理图
  • ¥15 vue2项目中,如何配置环境,可以在打完包之后修改请求的服务器地址
  • ¥20 微信的店铺小程序如何修改背景图
  • ¥15 UE5.1局部变量对蓝图不可见
  • ¥15 一共有五道问题关于整数幂的运算还有房间号码 还有网络密码的解答?(语言-python)
  • ¥20 sentry如何捕获上传Android ndk 崩溃
  • ¥15 在做logistic回归模型限制性立方条图时候,不能出完整图的困难
  • ¥15 G0系列单片机HAL库中景园gc9307液晶驱动芯片无法使用硬件SPI+DMA驱动,如何解决?