其实一直在用sqlserver 用的都是比较简单的查询,排个序啥的,最近发现sqlserver真的是强大,自己掌握的仅仅是凤毛麟角。所以决定在这里开一个笔记本,做记录。
1、关键字:行转列
1、建立表格
IF OBJECT_ID('tb') IS NOT NULL DROP TABLE tb go CREATE TABLE tb(姓名 VARCHAR(10),课程 VARCHAR(10),分数 INT) INSERT INTO tb VALUES('张三','语文',74) INSERT INTO tb VALUES('张三','数学',83) INSERT INTO tb VALUES('张三','物理',93) INSERT INTO tb VALUES('李四','语文',74) INSERT INTO tb VALUES('李四','数学',84) INSERT INTO tb VALUES('李四','物理',94) go SELECT * FROM tb
2、使用SQL Server 2000静态SQL
SELECT 姓名, max(CASE 课程 WHEN '语文' THEN 分数 ELSE 0 end)语文, max(CASE 课程 WHEN '数学' THEN 分数 ELSE 0 end)数学, max(CASE 课程 WHEN '物理' THEN 分数 ELSE 0 end)物理 FROM tb GROUP BY 姓名