sql行转列、列转行的方法

如题:有一张表EMP,里面有两个字段:name,chengji  有三条记录,分别表示语文(name) 70分,数学(name) 80分,英语(name) 58分,请用一条sql查询出这三条记录并以条件显示出来,大于等于80表示优秀,大于等于60表示及格,小于60分表示不及格!要求显示格式如上!

首先我们创建表,添加如题数据!

CREATE TABLE emp(NAME VARCHAR(20),chengji INT);

INSERT INTO emp VALUES(‘语文‘,70),(‘数学‘,80),(‘英语‘,58);

根据题目要求,我们需要将这三行的结果做判断,然后以列的形式显示,这其中有一个行转列的操作。

第一种sql写法:

SELECT MAX(CASE WHEN  NAME=‘语文‘ THEN (CASE WHEN chengji>=80  THEN ‘优秀‘ WHEN   chengji<80 AND chengji>=60 THEN ‘及格‘ ELSE  ‘不及格‘ END)  ELSE ‘‘ END) ‘语文‘  ,

MAX(CASE WHEN  NAME=‘数学‘ THEN (CASE WHEN chengji>=80  THEN ‘优秀‘ WHEN   chengji<80 AND chengji>=60 THEN ‘及格‘ ELSE  ‘不及格‘ END)  ELSE ‘‘ END)  ‘数学‘,

MAX(CASE WHEN  NAME=‘英语‘ THEN (CASE WHEN chengji>=80  THEN ‘优秀‘ WHEN   chengji<80 AND chengji>=60 THEN ‘及格‘ ELSE  ‘不及格‘ END) ELSE ‘‘ END ) ‘英语‘ FROM  emp

执行结果如下:

备注:上述sql中使用了max(case)这种用法,max这里的主要作用是为了在3次判断中,取到不为空字符串‘‘的标题,语文,数学,英语!

第二种写法采用group_concat函数也是可以拼接出如图所有要的结果写法如下:

SELECT GROUP_CONCAT(NAME SEPARATOR ‘|‘)  FROM   emp  UNION ALL   SELECT

GROUP_CONCAT(CASE WHEN chengji>=80  THEN ‘优秀‘ WHEN   chengji<80 AND chengji>=60 THEN ‘及格‘ ELSE  ‘不及格‘ END   SEPARATOR ‘|‘ ) FROM  emp

执行结果如下:

这样看,这个结果也还是可以接受, 这里采用了group_concat函数,将列的类容连接起来,作为行!不过这样的结果有点生硬的感觉!

补充一点:这里的sql写法我们可以看出,如果想要通过第一种写法。我们前面必须要知道列的内容如语文,数学,英语,但是第二种我们却不用知道! 这里我们想到了一种方法,通过存储过程,将想要的第一种方法的sql拼出来,然后执行这样的话,后面如果我们的表再添加列,或者减少列,也不会报错!

写法如下:

DELIMITER $$

USE `yhtest`$$

DROP PROCEDURE IF EXISTS `yhtest`$$

CREATE DEFINER=`root`@`%` PROCEDURE `yhtest`()

BEGIN

SET @sql = NULL;

SELECT

GROUP_CONCAT(DISTINCT

CONCAT(

‘MAX(CASE WHEN  NAME=‘,‘\‘‘,emp.name,‘\‘‘,‘THEN (CASE WHEN chengji>=80  THEN ‘, ‘\‘‘ ,‘优秀‘,‘\‘‘ ,‘ WHEN

chengji<80 AND chengji>=60 THEN ‘, ‘\‘‘ ,‘及格‘ ,‘\‘‘ ,‘ ELSE ‘, ‘\‘‘ ,‘不及格‘ ,‘\‘‘ ,‘ END)  ELSE ‘, ‘\‘‘,‘\‘‘,‘ END) ‘,‘\‘‘,emp.name,‘\‘‘

)

)

INTO @sql

FROM emp ;

SET @sql = CONCAT(‘select  ‘,@sql, ‘ from  emp‘);

PREPARE stmt1 FROM @sql;

EXECUTE stmt1;

DEALLOCATE PREPARE stmt1;

END$$

DELIMITER ;

调用一下: call yhtest();

插入几条数据!我们假设提前不知道有多少个科目!

INSERT INTO emp VALUES(‘物理‘,72),(‘体育‘,84);

这里有个问题!由于我们在存储过程中使用了group_concat函数,这个拼接函数最大拼接长度为1024(默认) 超过固定长度,截断处理! 由数据库参数group_concat_max_len 控制!我们可以根据需要认为调整!

group_concat  调整拼接符号 :group_concat(name  separator  ‘_‘)

group_concat  排序:group_concat(name order by name  separator  ‘_‘)

时间: 2024-11-05 03:06:06

sql行转列、列转行的方法的相关文章

Sql 行专列、列转行及分面

说明:本实例是以 SQL Server 2005 为运行环境的. 准备工作:创建一个名为 DB 的数据库(CREATE DATABASE DB). 一.T-SQL 行转列 1.创建如下表 CREATE  TABLE [Scores]  ( [ID] INT IDENTITY(1,1), --自增标识 [StuNo] INT,                         --学号 [Subject] NVARCHAR(30),     --科目 [Score] FLOAT           

Sql server 中将数据行转列列转行(二)

老规矩,先弄一波测试数据,数据填充代码没有什么意义,先折叠起来: /* 第一步:创建临时表结构 */ CREATE TABLE #Student --创建临时表 ( StuName nvarchar(20), --学生名称 Chinese int, Math int, English int ) DROP TABLE #Student --删除临时表 SELECT * FROM #Student --查询所有数据 INSERT INTO #Student(StuName,Chinese,Math

Sql server 中将数据行转列列转行(一)

在做一些数据分析与数据展示时,经常会遇到行转列,列转行的需求,今天就来总结下: 在开始之前,先来创建一个临时表,并且写入一些测试数据: /* 第一步:创建临时表结构 */ CREATE TABLE #Student --创建临时表 ( StuName nvarchar(20), --学生名称 StuSubject nvarchar(20),--考试科目 StuScore int --考试成绩 ) DROP TABLE #Student --删除临时表 SELECT * FROM #Student

sql 行转列 PIVOT 列转行 UNPIVOT

原文:sql 行转列 PIVOT 列转行 UNPIVOT 一: 现有表一(t_table1),想转为表二(t_table2)的格式. 表一: 年 公司 收入 2013 公司1 12 2013 公司2 22 2013 公司3 32 2012 公司1 42 2012 公司2 52 2012 公司3 62 表二: 年 公司1 公司2 公司3 2012 42 52 62 2013 12 22 32 可使用sql2005之后提供的PIVOT 具体操作如下: select * from   t_table1

sql 行专列 列转行 普通行列转换

转载:http://www.cnblogs.com/newwind521/archive/2010/11/25/1887203.html sql 行专列 列转行 普通行列转换 /* 标题:普通行列转换(version 2.0) 作者:爱新觉罗.毓华 时间:2008-03-09 地点:广东深圳 说明:普通行列转换(version 1.0)仅针对sql server 2000提供静态和动态写法,version 2.0增加sql server 2005的有关写法.  问题:假设有张学生成绩表(tb)如

SQL Server将一列的多行内容拼接成一行的实现方法

SQL Server将一列的多行内容拼接成一行的实现方法 投稿:mdxy-dxy 这篇文章主要介绍了SQL Server将一列的多行内容拼接成一行的实现方法,需要的朋友可以参考下 下面大家先看下示例代码: 示例 昨天遇到一个SQL Server的问题:需要写一个储存过程来处理几个表中的数据,最后问题出在我想将一个表的一个列的多行内容拼接成一行,比如表中有两列数据 : 类别 名称 AAA 企业1 AAA 企业2 AAA 企业3 BBB 企业4 BBB 企业5 我想把这个表变成如下格式: 类别 名称

Sql 行转换为列 以及列转换为行的心得

这是 创建数据库的脚本文件 CREATE TABLE [dbo].[stu]( [学号] [nvarchar](255) NOT NULL, [姓名] [nvarchar](255) NULL, [性别] [nvarchar](255) NULL, [专业] [nvarchar](255) NULL, [院系] [nvarchar](255) NULL ) ON [PRIMARY] GO INSERT [dbo].[stu] ([学号], [姓名], [性别], [专业], [院系]) VALU

MSSQLServer 纵向表转横向表 横向表转纵向表 行转列 列转行

MSSQLServer 纵向表转横向表  横向表转纵向表 建表语句及插入数据语句: CREATE TABLE Test_y( [Name] [nchar](10) NULL, [Course] [nchar](10) NULL, [Grade] [int] NULL ) insert into Test_y values ('张三','语文',75); insert into Test_y values ('张三','数学',80); insert into Test_y values ('张三

SQL2005语句实现行转列,列转行

在做报表时,经常需要将数据表中的行转列,或者列转行,如果不知道方法,你会觉得通过SQL语句来实现非常难.这里,我将使用pivot和unpivot来实现看似复杂的功能.这个功能在sql2005及以上版本才有. 引用MSDN:可以使用 PIVOT 和 UNPIVOT 关系运算符将表值表达式更改为另一个表.PIVOT 通过将表达式某一列中的唯一值转换为输出中的多个列来旋转表值表达式,并在必要时对最终输出中所需的任何其余列值执行聚合.UNPIVOT 与 PIVOT 执行相反的操作,将表值表达式的列转换为

SQL行转列 (及EAV模型获取数据)

参考文章: http://www.williamsang.com/archives/1508.html 情景简介 学校里面记录成绩,每个人的选课不一样,而且以后会添加课程,所以不需要把所有课程当作列.数据库grade里面数据如下图,假定每个人姓名都不一样,作为主键.本文以MySQL为基础,其他数据库会有些许语法不同. 数据库数据: 处理后效果: 下面介绍三种方法: 方法一: 1 2 3 4 5 SELECT DISTINCT  a.name, (SELECT score FROM grade b