首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SQL行转列和转行

而在SQL面试,一道出镜频率很高题目就是行转列和转行问题,可以说这也是一道经典SQL题目,本文就这一问题做以介绍分享。 ? 给定如下模拟数据集,这也是SQL领域经典学生成绩表问题。...scoreWide 考察问题就是通过SQL语句实现在这两种形态间转换,其中长表转为宽表即行转列,宽表转为长表即转行。...其基本思路是这样: 在长表数据组织结构,同一uid对应了多行,即每门课程一条记录,对应一组分数,而在宽表需要将其变成同一uid下仅对应一行 在长表,仅有一记录了课程成绩,但在宽表则每门课作为一记录成绩...,然后将该命名为course;第二个用反引号包裹起来课程名实际上是从宽表引用这一取值,然后将其命名为score。...这实际上对应一个知识点是:在SQL字符串引用用单引号(其实双引号也可以),而字段名称引用则是用反引号 上述用到了where条件过滤成绩为空值记录,这实际是由于在原表存在有空值情况,如不加以过滤则在本例中最终查询记录有

6.9K30

SQL 行转列和转行

行转列,转行是我们在开发过程中经常碰到问题。行转列一般通过CASE WHEN 语句来实现,也可以通过 SQL SERVER 运算符PIVOT来实现。用传统方法,比较好理解。...但是PIVOT 、UNPIVOT提供语法比一系列复杂SELECT…CASE 语句中所指定语法更简单、更具可读性。下面我们通过几个简单例子来介绍一下转行、行转列问题。...实际,可能支付方式特别多,而且逻辑也复杂很多,可能涉及汇率、手续费等等(曾经做个这样一个),如果支付方式特别多,我们CASE WHEN 会弄出一大堆,确实比较恼火,而且新增一种支付方式,我们还得修改脚本如果把上面的脚本用动态...这个是因为:对升级到 SQL Server 2005 或更高版本数据库使用 PIVOT 和 UNPIVOT 时,必须将数据库兼容级别设置为 90 或更高。...下面我们来看看转行,主要是通过UNION ALL ,MAX来实现。

5.3K20
您找到你想要的搜索结果了吗?
是的
没有找到

大战SQL类型及其属性

SQL学习历程 MySQL也有好几天没看了,部分语句都已不太熟悉,得赶快拿起来温习温习。...上次讲到了类型枚举类型,那么接下来还有集合记录长度,属性倒不是特别多,也就有空属性,描述以及默认值,所以学起来也是超快~ 集合字符串 集合跟枚举实际上很类似,实际上存储是数值,而不是字符串(集合可以多选...在MySQLtext文本字符串,是不占用记录长度:即额外存储,但text文本字符串也属于记录一部分;一定会占据记录部分长度:10个字节(用于其保护数据地址以及长度)。...下面可以开始讲述属性三个小部分啦~ 属性 是真正约束字段数据类型。...描述(注释) 描述:comment,起描述作用,无实际意义。是专门用来描述字段,根据表创建语句一起保存

1.3K30

SQL 将多数据转到一

假设我们要把 emp 表 ename、job 和 sal 字段值整合到一,每个员工数据(按照 ename -> job -> sal 顺序展示)是紧挨在一块,员工之间使用空行隔开。...使用 case when 条件1成立 then ename when 条件2成立 then job when 条件3成立 then sal end 可以将多数据放到一展示,一行数据过 case...when 转换后最多只会出来一个值,要使得同一个员工数据能依次满足 case when 条件,就需要复制多份数据,有多个条件就要生成多少份数据。...判断是否加空行也是 case when 条件,因此每个员工数据都要生成 4 份。...完整SQL 如下: SELECT CASE rn WHEN 1 THEN ename WHEN 2 THEN job WHEN 3 THEN

5.2K30

SQL行转列、转行

大家好,又见面了,我是你们朋友全栈君。 SQL行转列、转行 这个主题还是比较常见,行转列主要适用于对数据作聚合统计,如统计某类目的商品在某个时间区间销售情况。转行问题同样也很常见。...else 0 end) as char)) as 'str' from wyc_test a group by a.date; #转行...: 这就是最常见转行,主要原理是利用SQL里面的union,具体sql语句如下: Sql代码 select user_name, ‘语文’ COURSE , CN_SCORE as...: Sql代码 insert all into test_tb_grade3(USER_NAME,COURSE,SCORE) values(user_name, ‘语文’, CN_SCORE...CN_SCORE, MATH_SCORE, EN_SCORE from test_tb_grade2; commit; 别忘记commit操作,然后再查询TEST_TB_GRADE3,发现表数据就是转成行了

1.5K10

MySQL行转列和转行操作,附SQL实战

本文将详细介绍MySQL行转列和转行操作,并提供相应SQL语句进行操作。行转列行转列操作指的是将表格中一行数据转换为多数据操作。在MySQL,可以通过以下两种方式进行行转列操作。1....SUM(order_amount)部分是对原始数据相同年份订单金额进行求和。2. 自定义SQL语句除了使用PIVOT函数外,还可以使用自定义SQL语句实现行转列操作。...转行列转行操作指的是将表格数据转换为一行数据操作。在MySQL,可以通过以下两种方式进行列转行操作。1....自定义SQL语句除了使用UNPIVOT函数外,还可以使用自定义SQL语句实现转行操作。这种方法需要使用到MySQLUNION ALL语句。...结论MySQL行转列和转行操作都具有广泛应用场景,能够满足各种分析和报表需求。在实际应用,可以根据具体需求选择相应MySQL函数或编写自定义SQL语句进行操作。

11.6K20

SQL Server 数据库调整表顺序操作

SQL Server 数据库中表一旦创建,我们不建议擅自调整列顺序,特别是对应应用系统已经上线,因为部分开发人员,不一定在代码中指明了列名。...表是否可以调整列顺序,其实可以自主设置,我们建议在安装后设置为禁止。 那么,如果确实需要调整某一顺序,我们是怎么操作呢? 下面,我们就要演示一下怎么取消这种限制。...当然,通过取消限制演示,相信大家也知道了怎么添加限制了。...需求及问题描述 1)测试表 Test001 (2)更新前 (3)例如,需求为调整 SN5 和SN4序列 点击保存时报错 修改数据库表结构时提示【不允许保存更改。...您所做更改要求删除并重新创建以下表。您对无法重新创建标进行了更改或者启用了“阻止保存要求重新创建表更改"选项。】

4K20

SQL删除多语句写法

最近在写SQL过程中发现需要对一张表结构作调整(此处是SQL Server),其中需要删除多,由于之前都是一条SQL语句删除一,于是猜想是否可以一条语句同时删除多,如果可以,怎么写法?...第一次猜想如下(注意:此处是猜想,非正确写法): ALTER TABLE TableName DROP COLUMN column1,column2 但是执行后,发现语法错误, 于是改成如下方式:...ALTER TABLE TableName DROP COLUMN column1,COLUMN column2 执行正确,之后查看表结构,发现已删除,证明猜想正确。...以上所述是小编给大家介绍SQL删除多语句写法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家。在此也非常感谢大家对开源独尊支持!

3.5K20

实战演练:通过伪、虚拟实现SQL优化

一.通过伪、虚拟实现SQL优化 慢 SQL 文本如下: ? SQL 执行时长达 38S,获取 361 条数据结果返回。 SQL 执行计划如下: ?...虚拟实现SQL优化 分析 SQL 可知,SQL 性能瓶颈在于 a.minute = DATE_FORMAT(b.create_time, '%H:%i') 两表之间关联关系,SQL 无法通过表之间关联关系直接驱动...伪引入,可以强制 SQL 改变表之间关联顺序,获得想要执行计划。将 SQL 改写成如下方式: ? SQL 在 0.004s 之后即返回查询结果。 执行计划如下: ?...,业务许多 SQL 中出现错误结果返回和反应数据库整体缓慢。...,等价改写SQL改变表驱动方式,也仅仅只将 SQL 执行时间由 13s 优化为7s,SQL 真正性能瓶颈在于对 150W 数据 inputlog 表按 ShenFenZhengID 去重。

1.7K31

Mysql类型

Mysql类型: 数字类型 字符串类型 布尔型 日期时间类型 数字类型: 1个字节=8比特,但数字里有一个比特用于符号占位 TINYINT 占用1个字节,表示范围:-128~127 SMALLINT...支持范围是1000-01-01 ~ 9999-12-31 TIME 支持范围是00:00:00 ~ 23:59:59 DATETIME 支持范围是1000-01-01 00:00:00 ~ 9999...电话、手机号码:有格式要求 用户名:必须唯一 登录密码:密码不能为空字符串且长度不能少于N位 员工所在部门:可取值必须在部门表存在过 主键约束: 列名 类型 PRIMARY KEY 声明为“...表中所有的记录行会自动按照主键列上值进行排序。 一个表至多只能有一个主键。 唯一约束: 列名 类型 UNIQUE 声明为“唯一”列上不能出现重复值,但可以出现多个NULL值。...非空约束: 列名 类型 NOT NULL 声明为“非空”约束列上不能出现NULL,但可以重复 检查约束对于Mysql不支持 默认值约束 列名 类型 Default 值 声明为“默认值”约束列上没有值将会默认采用默认设置

6.3K20

删除 NULL 值

今天接到一个群友需求,有一张表数据如图 1,他希望能通过 SQL 查询出图 2 结果。 ? 图 1 原始数据 ?...图 2 输出结果 先来分析图 1 是怎么变成图 2,图1 tag1、tag2、tag3 三个字段都存在 NULL 值,且NULL值无处不在,而图2 里面的NULL只出现在这几个字段末尾。...那用 SQL 怎么表示呢? 有一个思路:把每一去掉 NULL 后单独拎出来作为一张独立表,这个表只有两个字段,一个是序号,另一个是去 NULL 后值。...一个比较灵活做法是对原表数据做转行,最后再通过行转列实现图2 输出。具体实现看下面的 SQL(我偷懒了,直接把原数据通过 SELECT 子句生成了)。...,按值在原表列出现顺序设置了序号,目的是维持同一相对顺序不变。

9.7K30

SQL Server 2014聚集存储索引

SQL Server 2012首次引入了基于存储数据格式存储方式。叫做“存储索引”。..., rowversion , sql_variant,精度大于18 decimal,CLR 和xml等)    另一方面,对于索引900字节限制也不适用与存储索引。...在SQL Server2012 ,只能创建非聚集存储索引,并且不能更新。为了更新你必须删除索引,然后进行插入、更新或者删除操作后在重建索引。...这个存储索引扫描操作符如下所示: ? 如上所示,Estimated I/O Cost从0.183866下降到0.0112731,这是因为SQL引擎只检索需要,节省了IO和内存资源。...与非聚集索引创建类似,选择,然后这些没有排序也不能使用Include选项: ? 下图中我在SQL Server2014 企业版,创建聚集索引: ?

98340

SQL Server 2014聚集存储索引

SQL Server 2012首次引入了基于存储数据格式存储方式。叫做“存储索引”。..., rowversion , sql_variant,精度大于18 decimal,CLR 和xml等)    另一方面,对于索引900字节限制也不适用与存储索引。...在SQL Server2012 ,只能创建非聚集存储索引,并且不能更新。为了更新你必须删除索引,然后进行插入、更新或者删除操作后在重建索引。...下图中我在SQL Server2014 企业版,创建聚集索引: image.png 需要注意是如果在表上已经有其他索引,尝试创建聚集存储索引就会出现错误,正如我们之前说,同一个表不能或者其他索引...总结: 存储索引是一个使用SQL Server性能优化方案,通过减少IO消耗,尤其对数据仓库和BI查询都是由明显性能提升。它通过排序数据作为存储,然后压缩,并使用批处理来处理数据。

95790
领券