使用 SQL 将单元格值显示为列名

发布于 2024-12-21 19:21:30 字数 367 浏览 0 评论 0原文

我在数据库中有如下表:

Name        Grade       Subject

Ami           HD         Java
Ami           D          C++
Bec           D          Java
Bec           P          C++

是否可以仅使用 SQL 以下面给出的格式显示它:

Name       Java       C++

Ami        HD         D
Bec        D          P

我已经努力尝试,但找不到解决方案。

谢谢。

I have got table as given below in database:

Name        Grade       Subject

Ami           HD         Java
Ami           D          C++
Bec           D          Java
Bec           P          C++

Is it possible to display it in format given below only using SQL:

Name       Java       C++

Ami        HD         D
Bec        D          P

I have tried hard, but couldn't find a solution.

Thank you.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

_失温 2024-12-28 19:21:30

试试这个:

SELECT
  Name, 
  MAX(CASE Subject WHEN 'C++'  THEN Grade END) 'C++',
  MAX(CASE Subject WHEN 'Java' THEN Grade END) 'Java'
FROM @test
GROUP BY Name;

您的表的问题是没有可以聚合列的数值,因此您可以使用 Min 或 max 作为聚合。
您可以在数据资源管理器此处查看正在运行的查询< /a>

Try this:

SELECT
  Name, 
  MAX(CASE Subject WHEN 'C++'  THEN Grade END) 'C++',
  MAX(CASE Subject WHEN 'Java' THEN Grade END) 'Java'
FROM @test
GROUP BY Name;

The problem with your table is that there is no numeric value you can aggregate your columns with, so you can use Min or max as an aggregate.
You can see the query in action in Data Explorer here

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文