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

SQL转列和列转行

而在SQL面试,一道出镜频率很高题目就是转列和列转行问题,可以说这也是一道经典SQL题目,本文就这一问题做以介绍分享。 ? 给定如下模拟数据集,这也是SQL领域经典学生成绩表问题。...01 转列:sum+if 在行转列,经典解决方案是条件聚合,即sum+if组合。...其基本思路是这样: 在长表数据组织结构,同一uid对应了多行,即每门课程一条记录,对应一组分数,而在宽表需要将其变成同一uid下仅对应一 在长表,仅有一列记录了课程成绩,但在宽表则每门课作为一列记录成绩...一变多行,那么复制最直观实现当然是使用union,即分别针对每门课程提取一张衍生表,最后将所有课程衍生表union到一起即可,其中需要注意字段对齐 按照这一思路,给出SQL实现如下: SELECT...这实际上对应一个知识点是:在SQL字符串引用用单引号(其实双引号也可以),而列字段名称引用则是用反引号 上述用到了where条件过滤成绩为空值记录,这实际是由于在原表存在有空值情况,如不加以过滤则在本例中最终查询记录有

7K30

SQL 转列和列转行

转列,列转行是我们在开发过程中经常碰到问题。转列一般通过CASE WHEN 语句来实现,也可以通过 SQL SERVER 运算符PIVOT来实现。用传统方法,比较好理解。...但是PIVOT 、UNPIVOT提供语法比一系列复杂SELECT…CASE 语句中所指定语法更简单、更具可读性。下面我们通过几个简单例子来介绍一下列转行、转列问题。...这也是一个典型转列例子。...上面两个列子基本上就是转列类型了。但是有个问题来了,上面是我为了说明弄一个简单列子。...这个是因为:对升级到 SQL Server 2005 或更高版本数据库使用 PIVOT 和 UNPIVOT 时,必须将数据库兼容级别设置为 90 或更高。

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

SQL 找出分组具有极值

这些需求有两个共同点:一是需要做分组,有按部门分组、有按科目、也有按用户分组;二是在分组里面找到存在极值,是整行数据,而不只是极值。...窗口函数 如果你在用 MySQL 5.8+,窗口函数可能是你最先想到办法,因为它足够简洁、简单。 先按部门分组,再对组内按照薪资降序排序,取排序序号为 1 即为部门最高薪资员工信息。...子查询 如果你数据库还不支持窗口函数,那可以先对 emp 分组,取出每个部门最高薪资,再和原表做一次关联就能获取到正确结果。...b.sal WHERE b.sal IS NULL ORDER BY a.deptno 我们知道,在SELECT * FROM a left join b on 关联条件 语句中 ,不论在 b 表是否有数据可以和...当 a.sal 是分组最大值时,a.sal < b.sal 条件不成立,关联出来结果 b 表数据为 NULL。

1.7K30

排序数组单个元素

来源: lintcode-排序数组单个元素 描述 给定一个排序数组,只包含整数,其中每个元素出现两次,除了一个出现一次元素。 找到只出现一次单个元素。...从index=0开始,与之后每一个元素比较,如果遇到相同,则将两个元素一起移除掉,如果遍历至结尾,还没有和当前元素相同,则返回当前元素. 但是今天我不用这两个方法,使用位运算符来解决....异或(^): 两个操作数,相同则结果为0,不同则结果为1。 比如:7^6=1;怎么计算呢?当然不是直接减法了!...比如: 两个相同数异或为0....出现两次数字异或之后都为0,拿到0和唯一出现一次数字异或,结果就是所求只出现一次数字. 所以此题机智解法就是:对数组所有数字异或即可.

2.2K40

table转列sql详解

table转列sql详解 tabele转列资料,网上搜一下很多。大家照着网上copy就可以实现自己想要功能。但是大家在实现功能后是否想过转列为什么要这样写?...5    math    93.0 6    chinese    67.0 7    math    83.0 8    chinese    77.0 8    math    84.0 3 转列后结果...例如示例数据,可以先假设subject数据[chinese,math]是已知,这样问题就简化了许多 2 当已知了chinese,math后,我们至少要先得到转换后tabel结构 如下; select...3结果与我们想要已经非常接近了,只需再做一个sum()处理,就OK了 select stuid, sum(case subject when 'chinese' then score else...可以根据subject值去动态sql语句 看下面的一段代码 declare @sql varchar(2000) set @sql='' select @sql =@sql+ ',case subject

70620

SQL代码隐藏数据库书单

但几次之后,发现精通数据库高手,并不是靠师傅培养就能出来。 举个例子:下面这段不到 3 SQL 代码,跑了 30 秒都没有出来结果,你怎么解决? ?...更多,就是第一朋友留言那样,“我没遇到过,我没从你群里学到技巧,你真没意思” 现实,也没好到哪里去!碰到这个问题,还是直接找我要答案,并不想知道,答案从哪里来。...在这段不到 3 SQL ,至少能反应出一个人看过哪些书,是真正看进去,弄明白那种看书。...因此即使这段经我手优化 SQL 执行了 1 秒,也比原先 SQL 快了 30 倍。 ? image 你看,就 319 行数据,用了 30 秒都没出来。...高手培养,真不是一朝一夕,还得看资质。 在晋级书单,一定会有数据库性能调优相关书。

1.6K10

SQL JOIN 子句:合并多个表相关完整指南

SQL JOIN JOIN子句用于基于它们之间相关列合并来自两个或更多表。...JOIN 以下是SQL不同类型JOIN: (INNER) JOIN:返回在两个表具有匹配值记录 LEFT (OUTER) JOIN:返回左表所有记录以及右表匹配记录 RIGHT (OUTER...希望这能帮助你理解SQLJOIN概念。如果有其他问题,请随时告诉我。 SQL INNER JOIN INNER JOIN关键字选择在两个表具有匹配值记录。...INNER JOIN 注意:INNER JOIN关键字仅返回两个表具有匹配值。...SQL LEFT JOIN关键字 SQL LEFT JOIN关键字返回左表(table1)所有记录以及右表(table2)匹配记录。如果没有匹配,则右侧结果为0条记录。

34010

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

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

12.5K20

SQL面试题003-比较

ORDER BY expr [ASC|DESC],... ) 其参数介绍如下: expression LAG() 函数返回 expression 当前行之前值,其值为 offset 其分区或结果集中行数...default_value 如果没有前一,则 LAG() 函数返回 default_value 。例如,如果 offset 为2,则第一返回值为 default_value 。...PARTITION BY 子句 PARTITION BY 子句将结果集中划分 LAG() 为应用函数分区。如果省略 PARTITION BY 子句,LAG() 函数会将整个结果集视为单个分区。...ORDER BY 子句 ORDER BY 子句指定在 LAG() 应用函数之前每个分区顺序。LAG() 函数可用于计算当前行和上一之间差异。...score 和上学期成绩 former_score 相比,得到一些判断标志位,在计算标志位过程,要注意将最苛刻条件放到第一个 CASE WHEN ,否则会得到意外结果。

6610

SQL 转列+窗口函数实例

今天继续和大家分享 HackerRank 上 SQL 编程挑战解题思路,这一次题目叫做“Occupations”,属于中等难度级别,答案提交成功率在 90% 左右。...Ashley Meera Jane Samantha Christeen Priya Julia NULL Ketty NULL Maria 解决方案 一般遇到“将一列所有唯一值作为新列名输出...”这种需求,我们首先想到就应该是转列,我之前写过一篇介绍SQL 转列通用实现文章,感兴趣朋友点进来看看。...做转列时分组依据是什么呢?即依据哪个字段分组。答案是依据每个职位姓名排序序号作为分组条件,而每个职位里面姓名出现序号可通过窗口函数求得。...Jennifer Actor 3 Ketty Actor 4 Samantha Doctor 1 Aamina Doctor 2 Julia Doctor 3 Priya 最后,我们把窗口函数和转列结合起来

2K10

Android单个View触摸事件分发机制

有时会遇见这个问题:假设一个textview文本显示一个网址,程序既给它注册长按事件操作,然后又会单击打开网页,也就是说既有onLongClick事件又有onClick事件。...,为该activity控件触摸事件进行分发,分发意思也就是说,如果该方法返回true,当你对activityview进行点击,长按,滑动等操作时Log信息如下: <span style="font-size...<em>中</em>,不会去执行任何操作,也就是触摸事件到这里就截止了,不会再往下传。...默认<em>的</em>是返回<em>的</em>false 在此声明:当屏幕进行触摸时首先是activity感受到该触摸事件,然后对事件进行分发处理,也就是说要不要传给activity<em>中</em><em>的</em>view进行处理。...activity首先将事件分发到你所定义<em>的</em>最外层<em>的</em>view,在本程序<em>中</em>我只定义了一个view,所以当dispatchTouchEvent返回false进行事件分发时就理所当然<em>的</em>分发给了我所定义<em>的</em>view

78620

如何写好 5000 SQL 代码

上千 SQL 代码常见,且永不过时!...我们几个 SQL 老玩家经常自吹, SQL 是半衰期最长编程语言。玩会它不用担心失业。 如何去阅读和拆解一个上千 SQL 存储过程,有四大步骤 :理解代码,分拆代码,改写代码和保存代码。...拆过无数代码,从上千缩减到 2 成,也组装过无数代码,从上百塞成了上千,业务所需。见过最长 SQL 代码超 5000 ,已简无所简,那就实事求是了。人有分分合合,有生命力代码也一样。...理解业务使你成为整个应用生态不可缺少一环。信息化目的不是写代码,最终落脚点还是利润。我觉得二爷(邱岳)肯定能赞同我这话。...你会成为别人口中“猪一样队友,坑货……” 《巴黎评论》,村上春树提到他小说经常修改 4 - 5 遍才交稿,而且编辑还需要修改。我们一遍过 SQL 就免检了?

55830

5000 SQL 源代码,怎么读?

“怎么,今天热焦玛少了点劲儿嘛,感觉?”我走近了小 C。 “L, 面对着满屏 SQL,谁都会提不起精神啊。何况这近 5000 代码,怎么看得过来嘛!...“哟,恭喜你,遇到这么极品 sp 啊。在我印象里面,经历了两次重构之后,上千代码,就那么几个,今天被你遇到了。...“你这一一个字段,是你自己设置吧,其实不需要那么格式化,反而更简单。你看啊,一个 Insert 被几十个字段隔成了两屏,容易造成思维停顿。两搞定事情,做复杂了。还显得代码量大,失去耐心。”...首先告诉自己,一遍读完就能通晓5000代码细节,是不可能事情。读代码前,耐心先行。接着就是开始第一遍阅读。...此时代码走读,我们不停留在具体技术末节上,比如 unpivot 语法是怎么样实现,为什么有里三层外三层嵌套,为什么这里用了动态 SQL 去拼接。

92020

如何写好 5000 SQL 代码

上千 SQL 代码常见,且永不过时!...我之前写过如何去阅读和拆解一个上千 SQL 存储过程,详情可见以下两篇文章: 如何提高阅读 SQL 源代码快感 如何写好上千 SQL 存储过程(附代码规范) 这两文中提到了四大步骤:理解代码,...拆过无数代码,从上千缩减到 2 成,也组装过无数代码,从上百塞成了上千,业务所需。见过最长 SQL 代码超 5000 ,已简无所简,那就实事求是了。人有分分合合,有生命力代码也一样。...如要参考这5000实战SQL代码,可以关注我微信公众号【有关SQL】,回复【5000】便可下载。 但装和拆并不是一个逆反过程!...既然如此,在我们赖以为生SQL阵营,这门吃饭技能一定是要好好磨练。 下面的领悟来自我实战真实想法,趟过无数次坑,用教训总结出来几条自认为极有用经验。

1K11

如何写好 5000 SQL 代码

上千 SQL 代码常见,且永不过时!...我之前写过如何去阅读和拆解一个上千 SQL 存储过程,详情可见以下两篇文章: 如何提高阅读 SQL 源代码快感 如何写好上千 SQL 存储过程(附代码规范) 这两文中提到了四大步骤:理解代码,...拆过无数代码,从上千缩减到 2 成,也组装过无数代码,从上百塞成了上千,业务所需。见过最长 SQL 代码超 5000 ,已简无所简,那就实事求是了。人有分分合合,有生命力代码也一样。...如要参考这5000实战SQL代码,可以关注我微信公众号【有关SQL】,回复【5000】便可下载。 但装和拆并不是一个逆反过程!...既然如此,在我们赖以为生SQL阵营,这门吃饭技能一定是要好好磨练。 下面的领悟来自我实战真实想法,趟过无数次坑,用教训总结出来几条自认为极有用经验。

59810
领券