SQL server 行转列 列转行
1.简单案例
  create database Hang
    go
  use Hang
  create table Students
  ( 
	  Name varchar(50),
	  Kemu varchar(50),
	  sor int
  )
  insert into Students values('张三','语文',8888)
  insert into Students values('张三','语文',85)
  insert into Students values('张三','数学',75)
  insert into Students values('李四','数学',95)
i  nsert into Students values('李四','语文',65)
  select * from   Students
----------------行转列-------------
select * from Students pivot(max(sor) for Kemu in(语文,数学))
as t
----------------列转行----------------
with Lie as (
select * from Students pivot(max(sor) for Kemu in(语文,数学))
as t
)
select *from Lie unpivot (sor for Kemu in(语文,数学))
as t
2.另一案例
select Name as 水果,
max(case RegionName when '北京' then Price else 0 end) 北京,
max(case RegionName when '广州' then Price else 0 end) 广州
from (
select f.Name,r.RegionName,rf.Price  from Fruits f 
join RegionPrice rf on f.ID =rf.FruitID
join Regions  r on rf.RegionID =r.id
) tb  group by Name
select f.Name,r.RegionName,rf.Price  from Fruits f 
join RegionPrice rf on f.ID =rf.FruitID
join Regions  r on rf.RegionID =r.id
select Name as 水果,
case RegionName when '北京' then Price else 0 end 北京,
case RegionName when '广州' then Price else 0 end  广州
from (
select f.Name,r.RegionName,rf.Price  from Fruits f 
join RegionPrice rf on f.ID =rf.FruitID
join Regions  r on rf.RegionID =r.id
) tb
select * from 
(
select f.Name,r.RegionName,rf.Price  from Fruits f 
join RegionPrice rf on f.ID =rf.FruitID
join Regions  r on rf.RegionID =r.id
) tb
pivot
(
max(tb.Price) for  tb.RegionName in
([广州],[北京])
) as a
SQL server 行转列 列转行的更多相关文章
- SQL Server自动化运维系列——关于邮件通知那点事(.Net开发人员的福利)
		
需求描述 在我们的生产环境中,大部分情况下需要有自己的运维体制,包括自己健康状态的检测等.如果发生异常,需要提前预警的,通知形式一般为发邮件告知. 邮件作为一种非常便利的预警实现方式,在及时性和易用性 ...
 - SQL Server中的标识列
		
一.标识列的定义以及特点 SQL Server中的标识列又称标识符列,习惯上又叫自增列. 该种列具有以下三种特点: .列的数据类型为不带小数的数值类型 .在进行插入(Insert)操作时,该列的值是由 ...
 - SQL Server 2016:内存列存储索引
		
作者 Jonathan Allen,译者 谢丽 SQL Server 2016的一项新特性是可以在“内存优化表(Memory Optimized Table)”上添加“列存储索引(Columnstor ...
 - SQL Server ->> ColumnStore Index(列存储索引)
		
Columnstored index是SQL Server 2012后加入的重大特性,数据不再以heap或者B Tree的形式存储(row level)存储在每一个数据库文件的页里面,而是以列为单位存 ...
 - Sql Server中的标识列(自增长字段)
		
一.标识列的定义以及特点 SQL Server中的标识列又称标识符列,习惯上又叫自增列.该种列具有以下三种特点: 1.列的数据类型为不带小数的数值类型2.在进行插入(Insert)操作时,该列的值是由 ...
 - SQL Server自动化运维系列——监控跑批Job运行状态(Power Shell)
		
需求描述 在我们的生产环境中,大部分情况下需要有自己的运维体制,包括自己健康状态的检测等.如果发生异常,需要提前预警的,通知形式一般为发邮件告知. 在上一篇文章中已经分析了SQL SERVER中关于邮 ...
 - SQL SERVER将某一列字段中的某个值替换为其他的值                                                       分类:            MSSQL             2014-11-05 13:11    67人阅读    评论(0)    收藏
		
SQL SERVER将某一列字段中的某个值替换为其他的值 UPDATE 表名 SET 列名 = REPLACE(列名 ,'贷','袋') SQL SERVER"函数 replace 的参数 ...
 - 【转载】SQL Server行转列,列转行
		
行转列,列转行是我们在开发过程中经常碰到的问题.行转列一般通过CASE WHEN 语句来实现,也可以通过 SQL SERVER 2005 新增的运算符PIVOT来实现.用传统的方法,比较好理解.层次清 ...
 - SQL Server 行转列,列转行。多行转成一列
		
一.多行转成一列(并以","隔开) 表名:A 表数据: 想要的查询结果: 查询语句: SELECT name , value = ( STUFF(( SELECT ',' + va ...
 - SQL Server 行转列,列转行
		
一.多行转成一列(并以","隔开) 表名:A 表数据: 想要的查询结果: 查询语句: SELECT name , value = ( STUFF(( SELECT ',' + va ...
 
随机推荐
- Php7.3  could not find driver
			
今天phpstudy升级php7.3,发现框架报错:could not find driver,后来发现默认php.ini的配置有几个是注释掉的,配置php.ini,修改如下 extension=my ...
 - java爬虫系列第五讲-如何使用代理防止爬虫被屏蔽?
			
本文内容 1.分析一下爬虫存在的问题及解决方案 2.webmagic中代理的使用 3.目前市面上一些比较好用的代理服务器 存在的问题 我们在使用爬虫过程中,大多都会遇到这样的问题:突然某一天爬虫爬不到 ...
 - 什么是mybatis?
			
[学习笔记] 什么是mybatis: Mybatis本质是一种半自动化的ORM框架,前身是ibatis,除了要pojo和映射关系之外,还需要些sql语句. 怎么看待ORM框架: 处理矛盾的,java程 ...
 - 对css盒模型的理解
			
介绍一下标准css的盒子模型?低版本IE的盒子模型有什么不同的? 1.有两种:IE盒子模型(怪异模式).W3c盒子模型(标准模式). 2.盒模型组成:内容(content).内边距(padding). ...
 - Linux学习历程——Centos 7 diff命令
			
一.命令介绍 diff命令用于比较文本差异. diff以逐行的方式,比较文本文件的异同处.如果指定要比较目录,则diff会比较目录中相同文件名的文件,但不会比较其中子目录. ------------- ...
 - ASP.NET基础知识汇总之WebConfig自定义节点详细介绍
			
之前介绍过Webconfig的具体知识ASP.NET基础知识汇总之WebConfig各节点介绍.今天准备封装一个ConfigHelper类,涉及到了自定义节点的东东,平时虽然一直用,但也没有系统的总结 ...
 - 华为笔记HOSTS,便于访问云端存储
			
# Copyright (c) - Microsoft Corp. # # This is a sample HOSTS file used by Microsoft TCP/IP for Windo ...
 - 【原创】小说:我是一条DQL
			
SQL执行流程图如下 本文改编自<高性能Mysql>,烟哥用小说的形式来讲这个内容. 序章 自我介绍 我是一条sql,就是一条长长的字符串,不要问我长什么样,因为我比较傲娇. 额~~不是我 ...
 - BAT面试题:请使用递归构建N叉树
			
题目要求: 现在我们拥有全国的省.市.县.镇的行政信息,比如 浙江省 -> 杭州市 -> 西湖区 --> xx街道,请将这些信息构建成一棵树,根节点为全国,叶子节点为镇. 我的误解: ...
 - Web后台快速开发框架
			
Web后台快速开发框架 Coldairarrow 目录 目录 第1章 目录 1 第2章 简介 3 第3章 基础准备 4 3.1 开发环境要求 4 3.2 ...