一个简单的SQL 行列转换语句
前端之家收集整理的这篇文章主要介绍了
一个简单的SQL 行列转换语句,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
一个简单的sql 行列转换
Author: eaglet
在数据库开发中经常会遇到行列转换的问题,比如下面的问题,部门,员工和员工类型三张表,我们要统计类似这样的列表
部门编号 部门名称 合计 正式员工 临时员工 辞退员工
1 A 30 20 10 1
这种问题咋一看摸不着头绪,不过把思路理顺后再看,本质就是一个行列转换的问题。下面我结合这个简单的例子来实现行列转换。
下面3张表
<div class="codetitle"><a style="CURSOR: pointer" data="47172" class="copybut" id="copybut47172" onclick="doCopy('code47172')"> 代码如下:
<div class="codebody" id="code47172">
if exists ( select
from sysobjects where id = object_id ( ' EmployeeType ' ) and type = ' u ' )
drop table EmployeeType
GO
if exists ( select from sysobjects where id = object_id ( ' Employee ' ) and type = ' u ' )
drop table Employee
GO
if exists ( select
from sysobjects where id = object_id ( ' Department ' ) and type = ' u ' )
drop table Department
GO
create table Department
(
Id int primary key,
Department varchar ( 10 )
)
create table Employee
(
EmployeeId int primary key,
DepartmentId int Foreign Key (DepartmentId) References Department(Id),-- DepartmentId,
EmployeeName varchar ( 10 )
)
create table EmployeeType
(
EmployeeId int Foreign Key (EmployeeId) References Employee(EmployeeId),-- EmployeeId,
EmployeeType varchar ( 10 )
)
描述部门,员工和员工类型之间的关系。
插入测试数据
<div class="codetitle">
<a style="CURSOR: pointer" data="38886" class="copybut" id="copybut38886" onclick="doCopy('code38886')"> 代码如下:
<div class="codebody" id="code38886">
insert Department values ( 1,' A ' );
insert Department values ( 2,' B ' );
insert Employee values ( 1,1,' Bob ' );
insert Employee values ( 2,' John ' );
insert Employee values ( 3,' May ' );
insert Employee values ( 4,2,' Tom ' );
insert Employee values ( 5,' Mark ' );
insert Employee values ( 6,' Ken ' );
insert EmployeeType values ( 1,' 正式 ' );
insert EmployeeType values ( 2,' 临时 ' );
insert EmployeeType values ( 3,' 正式 ' );
insert EmployeeType values ( 4,' 正式 ' );
insert EmployeeType values ( 5,' 辞退 ' );
insert EmployeeType values ( 6,' 正式 ' );