最近面试遇到了一道面试题,顿时有点迷糊,只说出了思路,后来百度了一下,整理了一下思路,于是记录下来,方便以后学习。(面试题请参见附件)

相关的数据表:

1.Score表

2.[User]表

SQL语句如下:

--方法一:静态SQL
复制代码 代码如下:
SELECT * FROM
(SELECT UID,Name, Score,ScoreName FROM Score,[User] WHERE Score.UID=[User].ID) AS SourceTable
PIVOT(AVG(Score)FOR ScoreName IN ([英语], [数学])) AS a

--方法二:动态SQL
复制代码 代码如下:
DECLARE @s NVARCHAR(4000)
SELECT @s = ISNULL(@s + ',', '') + QUOTENAME(ScoreName)
FROM (select distinct ScoreName from Score) as A ---列名不要重复

Declare @sql NVARCHAR(4000)
SET @sql='
select r.* from
(select UID,Name,ScoreName,Score from Score,[User] where Score.UID=[User].ID) as t
pivot
(
max(t.Score)
for t.ScoreName in ('+@s+')
) as r'
EXEC( @sql)

--方法三:Case When
复制代码 代码如下:
select
row_number() OVER(ORDER BY [User].ID) as 编号,
UID as 用户编号,
Name as 姓名,
max(case ScoreName when '英语' then Score else 0 end) 英语,
max(case ScoreName when '数学' then Score else 0 end) 数学
from Score,[User] WHERE Score.UID=[User].ID
group by UID,[User].ID,Name

更多相关文章

  1. Android,一个思路实现APP版本更新
  2. Android描画简单圆形
  3. 详解Android(安卓)TextView属性ellipsize多行失效的解决思路
  4. android 类似QQ 换皮肤 实现思路 apk资源共享
  5. 开始学习Android
  6. Android流媒体
  7. 读懂Android(安卓)(1):使用Android内部的DownloadProvider下载文
  8. Android(安卓)so注入( inject)和Hook(挂钩)的实现思路讨论
  9. 免 ROOT 卸载 Android(安卓)系统软件的思路和实现

随机推荐

  1. 屏幕方向android:screenOrientation
  2. android 传感器
  3. Android官方架构组件:Lifecycle
  4. Android兼容性优化-Android 8.0设置Activ
  5. Image
  6. 局域网调试Android
  7. Android 源码编译如何确定模块安装的位置
  8. Android Dimension
  9. EditText focus
  10. android添加广告之--admob