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

SQL行转列和转行

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

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

SQL 行转列和转行

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

5.4K20

SQLDECIMAL()函数

大家好,又见面了,我是你们朋友全栈君。 Decimal为SQL Server 数据类型,属于浮点数类型。一个decimal类型数据占用了2~17个字节。...Decimal 数据类型Decimal 变量存储为 96 位(12 个字节)无符号整型形式, Decimal类型消除了发生在各种浮点运算舍入误差,并可以准确地表示28个小数位。...Decimal数据类型可以在Visual Studio编辑器中使用,只要在一个浮点类型值后加一个大写或小写M,则编辑器会认为这个浮点类型值是一个Decimal类型。...这种128位高精度十进制数表示法通常用在财务计算。要注意是,在.NET环境,计算该类型值会有性能上损失,因为它不是基本类型。...decimal SQL-92 同义字是 dec 和 dec(p, s)。numeric 功能相当於 decimal。

2.1K10

SQL 聚集函数

SQL 聚集函数SQL 函数包含了算术函数,字符串函数,日期函数,转换函数。还有一函数,叫做聚集函数SQL 聚集函数是对一组数据进行汇总函数,输入是一组数据集合,输出是单个值。...有哪些聚集函数 SQL 聚集函数,有最大值,最小值,平均值。 ? image Count 使用 例子:查询heros hp_max 大于6000 英雄。...想要查询最⼤⽣命值⼤于6000,且有次要定位英雄数量,需要使⽤COUNT函数。...需要说明是,COUNT(role_assist)会忽略值为NULL数据⾏,⽽COUNT(*)只是统计数据⾏数,不管某个字段是否为NULL。...对数据行不同取值进行聚集,过滤掉重复,可以写成如下: SELECT COUNT(DISTINCT hp_max) FROM heros 运⾏结果为61。

1.3K10

sqldecode用法_sql求和函数

decode() 函数语法: 1 Select decode(columnname,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值) 2 3 From talbename 4...5 Where … 其中:columnname为要选择table中所定义column;    缺省值可以是你要选择column name本身,也可以是你想定义其他值,比如Other等; 主要作用...) sale from output 若只与一个值进行比较: Select monthid ,decode(sale, NULL,‘---’,sale) sale from output decode可使用其他函数...SELECT NAME,NVL(TO_CHAR(COMM),'NOT APPLICATION') FROM TABLE1; 如果用到decode函数: select monthid,decode(nvl...(sale,6000),6000,'NG','OK') from output;   sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1, 用如下SQL语句取较小值: select monthid

1.5K40

Power Query批量处理函数详解

; 第2参数是需要改变及操作(正常情况是由列名和操作函数组成,也可以是空列表); 第3参是去除第2参数中指定后剩余所需要进行处理函数; 第4参数是找不到第2参数指定标题时是忽略处理(1)还是返回错误处理...---- 例1: 此函数必要参数只有2个,所以我们先用最基础2个参数来进行操作。 ? 如果要把成绩统一减10分的话,那就在第2参数这里使用列名和对应操作函数即可。...例3 第3个参数是一个函数,是在第2参数指定以外表格所有需要进行操作。 在前面的操作,成绩和学科都有了操作,那剩余其他(姓名列)也需要进行操作,那就要使用到第3参数了。...如果第2参数学科写错或者定义了其他未在操作表列名,则可以通过第4参数来控制返回。...因为指定里有 “班级”,但是在原来表格不存在,所以会产生错误,但是第4参数有指定1,也就是忽略错误,最终返回结果如图所示。除了找到成绩列表外,其余数据都在后面添加了个“A”。 ?

2.4K21

SQL知识大全(六):SQL开窗函数

在数据分析,窗口函数是我们经常用到函数,今天文章我们总结了常用各类窗口函数并给出实例。 ? 一 创建数据集 ?...聚合函数开窗和专用窗口函数是一致,其形式为: ‹窗口函数› over (partition by ‹用于分组列名› order by ‹用于排序列名›) 聚合函数窗口函数,加不加order...lag和lead函数可以在同一次查询取出同一字段前N行数据(lag)和后N行数据(lead)。...这是一个返回单个(标量)值任何类型表达式。scalar_expression 不能为分析函数。简单地 来说就是,要取。...offset默认值为1, offset 可以是、子查询或其他求值为正整数表达式,或者可隐式转换为bigint。offset 不能是负数值或分析函数

4K20

大战SQL类型及其属性

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

1.3K30

函数

概念 散概念属于查找,它不以关键字比较为基本操作,采用直接寻址技术。在理想情况下,查找期望时间为O(1)。 hash函数就是把任意长输入字符串变化成固定长输出字符串一种函数。...输出字符串长度称为hash函数位数。 散(Hashing)通过散函数将要检索项与索引(散,散值)关联起来,生成一种便于搜索数据结构(散列表)。...应用 目前应用最为广泛hash函数是SHA-1和MD5,大多是128位和更长。hash函数在现实生活应用十分广泛。...哈希函数构造准则 hash函数构造准则:简单、均匀。 (1)散函数计算简单,快速; (2)散函数能将关键字集合K均匀地分布在地址集{0,1,…,m-1}上,使冲突最小。...注意:由于直接定址所得地址集合和关键字集合大小相同。因此,对于不同关键字不会发生冲突。但实际能使用这种哈希函数情况很少。

89430

SQL 将多数据转到一

假设我们要把 emp 表 ename、job 和 sal 字段值整合到一,每个员工数据(按照 ename -> job -> sal 顺序展示)是紧挨在一块,员工之间使用空行隔开。...使用 case when 条件1成立 then ename when 条件2成立 then job when 条件3成立 then sal end 可以将多数据放到一展示,一行数据过 case...判断是否加空行也是 case when 条件,因此每个员工数据都要生成 4 份。...如果使用数据库不支持窗口函数呢?在 MySQL 里可以使用用户变量,使用用户变量只是模拟了窗口函数实现,并没有什么新意。...我们可从派生表下手,把本该由窗口函数生成序号任务交给派生表,这样就不需要窗口函数了。

5.2K30

SQLcast()函数「建议收藏」

大家好,又见面了,我是你们朋友全栈君。 CAST函数用于将某种数据类型表达式显式转换为另一种数据类型。CAST()函数参数是一个表达式,它包括用AS关键字分隔源值和目标数据类型。...AS:用于分隔两个参数,在AS之前是要处理数据,在AS之后是要转换数据类型。...data_type:目标系统所提供数据类型,包括bigint和sql_variant,不能使用用户定义数据类型。 可以转换类型是有限制。...这个类型可以是以下值其中一个: 二进制,同带binary前缀效果 : BINARY 字符型,可带参数 : CHAR() 日期 : DATE 时间: TIME 日期时间型...精度是总数字位数,包括小数点左边和右边位数总和。

1.8K10

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券