本文将讨论10个最重要的SQL概念。在准备面试时,你应该主要关注这些概念。 开始吧! 1. CASE WHEN 许多问题都可能需要使用CASE-WHEN语句,仅仅是因为这个概念功能如此之多。...在根据其他变量分配某个值或类时,用CASE-WHEN可以编写复杂的条件语句。 鲜为人知的是,用它还可以透视数据。...例如,如果你已有“月(month)”列,又希望为每个month创建一个单独的列,则可以使用CASE WHEN语句来透视数据。 示例问题:编写一个SQL查询重新排列表样式,以使每个月对应一个收入栏。...SELECT DISTINCT SELECT DISTINCT语句是一定要记牢的。将SELECT DISTINCT语句与聚合函数(即第三个概念)一起使用是非常常见的。...这是种好方法,可以解决需要多次按序查询以生成给定结果的特殊问题。子查询和WITH AS语句在查询中的使用次数都非常多,因此你需要知道如何使用它们。
1、控制流程函数 case…when 根据值判断返回值,类比编程中的IF-ELSE判断。...MIN([distinct] expr) 求最小值 SUM([distinct] expr) 求累加和 二、自定义函数 1、概念简介 函数存储着一系列sql语句,调用函数就是一次性执行这些语句。...所以函数可以降低语句重复。函数注重返回值,而触发器注重执行过程,所以一些语句无法执行。所以函数并不是单纯的sql语句集合。...2、使用方式 create function 函数名([参数列表]) returns 数据类型 begin sql语句; return 值; end; 参数列表的格式是:变量名 数据类型。...三、触发器 1、触发器简介 触发器是特殊的存储过程,不同的是存储过程要用CALL来调用,而触发器不需要使用CALL。也不需要手工启动,只要当一个预定义的事件发生的时候,就会被MYSQL自动触发调用。
扯远了,飞回来~~~ 创建数据库 SQL常用规则0 数据库的名称只能使用小写字母 关系数据库以行为单位读写数据 SQL根据功能不同可以分为三类,其中使用最多的是DML(数据操纵语言) SQL语句以分号(...;)结尾 SQL不区分关键字的大小写,但是约定俗成的写法是:关键字大写、表名的首字母大写、其余(列名等)小写 字符串和日期常数需要使用单引号(’)括起来 数字常数无需加注单引号 SQL语句的单词之间需要使用半角空格或换行符来进行分割...WHERE语句来选择记录 SQL常用规则2 SQL语句可以使用AS关键字为列设定别名,设定汉字别名时需要使用双引号(’’)括起来 在SELECT语句中可以使用DISTINCT来删除重复行 WHERE子句要紧跟在...定义视图时不要使用ORDER BY子句 视图和表需要同时进行更新,因此通过汇总得到的视图无法进行更新 子查询作为内层查询会首先执行 标量字查询就是返回单一值的子查询 在细分的组内进行比较时,需要使用关联子查询...CASE 表达式 SQL常用规则6 谓词就是返回值为真值的函数 通常指定关联子查询作为EXIST的参数 作为EXIST参数的子查询中经常会使用SELECT * CASE表达式中的END不能省略 SQL
该命令会生成两个文件,一个是.sql文件,一个是.txt文件,其中.sql文件保存表的结构,如果定义了--no-create-info,则该文件的大小为0Kb,什么内容都没有,.txt文件是数据文件,里面包含了我们导出的数据...如果我们用select into outfile的方法来导出cvs格式的文件,那么我们需要使用如下命令: select * from table_name into outfile '/tmp/table_name.cvs...,某个业务SQL使用了count(distinct 字段)的方法来统计某个场景中的人数,发现一直报内存不足的问题。...我大概模拟了一个相同的测试数据,说明一下这个SQL,如下: 首先来看表中的数据: mysql> select * from test0; +------+------+-------+ | id |...使用了count(distinct )的方法,乍一看满足了我们的需求,来看这个SQL的执行计划(为了避免group by操作后的排序对执行计划进行干扰,我特意加了order by null语法来分析):
哈希索引的最大特点是访问速度快,但也存在下面的一些缺点:MySQL 需要读取表中索引列的值来参与散列计算,散列计算是一个比较耗时的操作。也就是说,相对于 B-树索引来说,建立哈希索引会耗费更多的时间。...你写SQL语句的时候,没有主动指定使用哪个索引的话,用哪个索引是由MySQL来确定的。我们日常开发中,不断地删除历史数据和新增数据的场景,有可能会导致MySQL选错索引。那么有哪些解决方案呢?...Mysql中的索引可以以一定顺序引用多个列,这种索引叫做联合索引,一般的,一个联合索引是一个有序元组,其中各个元素均为数据表的一列,实际上要严格定义索引需要用到关系代数。...慢SQL的主要原因包括:SQL语句设计不合理、数据库索引设置不当、数据库表结构设计不合理、数据库服务器资源不足等。为了提高线上业务的性能,我们需要对慢SQL进行优化。...我们这节主要介绍使用EXPLAIN优化SQL语句。使用EXPLAIN关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的。分析你的查询语句或是表结构的性能瓶颈。
SQL语句的单词之间需要使用半角空格或换行符来进行分割 表的创建 CREATE TABLE ( , ...FROM WHERE ; SQL常用规则2 SQL语句可以使用AS关键字为列设定别名,设定汉字别名时需要使用双引号(’’)括起来 在SELECT语句中可以使用DISTINCT...SQL常用规则5 表中存储的是实际数据,而视图中保存的是从表中提取数据所使用的SELECT语句 应该将经常使用的SELECT语句做成视图 定义视图时不要使用ORDER BY子句 视图和表需要同时进行更新...,因此通过汇总得到的视图无法进行更新 子查询作为内层查询会首先执行 标量字查询就是返回单一值的子查询 在细分的组内进行比较时,需要使用关联子查询 ABS函数(求绝对值) ABS(数值) MOD函数(求余...ELSE END SQL常用规则6 谓词就是返回值为真值的函数 通常指定关联子查询作为EXIST的参数 作为EXIST参数的子查询中经常会使用SELECT * CASE表达式中的END不能省略
Hive总结 一、本质 Hive基于一个统一的查询分析层,通过SQL语句的方式对HDFS上的数据进行查 询、统计和分析。...SQL解析引擎,将SQL语句转译成MR Job 下例:Hive写的wordcount 三、HQL与SQL对比 四、Hive体系架构 可以将Hive体系分为三层,从上至下依次为用户接口、语句转换、数据存储...时存在大量特殊值: select cast(count(distinct user_id)+1 as bigint) as user_cnt from tab_a where user_id is not...1个reducer来完成笛卡尔积 • Union all: 先做union all再做join或group by等操作可以有效减少MR过程,多个Select,也只需一个MR • Multi-insert...on a.usrid=b.usrid; 3.UDF • UDF函数可以直接应用于select语句,对查询结构做格式化处理后,再输出内容。
有趣的电影:where条件使用,SQL中奇偶数的判断方法 交换性别:case语句和if语句的使用, 595-找出最大的国家 题目 如果一个国家的面积超过300万平方公里,或者人口超过2500...group by class) as temp where num >= 5; 通过having过滤来解决,注意使用distinct,有些可能是重复记录 select class from courses...交换所有的 f 和 m 值(例如,将所有 f 值更改为 m,反之亦然)。要求只使用一个更新(Update)语句,并且没有中间的临时表。...注意,您必只能写一个 Update 语句,请不要编写任何 Select 语句 ?...答案 首先需要了解更新语句的基本操作: update 表名 set 列名=修改后的值; 自己的解决方案中case语句略微复杂啦,可以进行简化,如同方法2 -- 方法1:自己方案 update salary
因此,Stratascratch的创始人Nathan Rosidi以及我觉得我认为10个最重要和相关的中级到高级SQL概念。...4.使用CASE WHEN枢转数据 您很可能会看到许多要求在陈述时使用CASE WHEN的问题,这只是因为它是一种多功能的概念。如果要根据其他变量分配某个值或类,则允许您编写复杂的条件语句。...例如,如果您有一个月列,并且您希望为每个月创建一个单个列,则可以使用语句追溯数据的情况。 示例问题:编写SQL查询以重新格式化表,以便每个月有一个收入列。...同样,除了在查询/表中相同数量的列,其中不再与每个查询/表比较单个列。 6.自联结 一个SQL表自行连接自己。你可能会认为没有用,但你会感到惊讶的是这是多么常见。...请注意,使用dense_rank(),Daniel排名第3,而不是第4位()。 8.计算Delta值 另一个常见应用程序是将不同时期的值进行比较。例如,本月和上个月的销售之间的三角洲是什么?
4.使用CASE WHEN枢转数据 您很可能会看到许多要求在陈述时使用CASE WHEN的问题,这只是因为它是一种多功能的概念。如果要根据其他变量分配某个值或类,则允许您编写复杂的条件语句。...例如,如果您有一个月列,并且您希望为每个月创建一个单个列,则可以使用语句追溯数据的情况。 示例问题:编写SQL查询以重新格式化表,以便每个月有一个收入列。...同样,除了在查询/表中相同数量的列,其中不再与每个查询/表比较单个列。 6.自联结 一个SQL表自行连接自己。你可能会认为没有用,但你会感到惊讶的是这是多么常见。...例如,您可能需要将数据分组组或将可变格式从DD-MM-Yyyy转换为简单的月份。 示例问题:给定天气表,写一个SQL查询,以查找与其上一个(昨天)日期相比的温度较高的所有日期的ID。...我希望这有助于您在面试准备中 - 我相信,如果您知道这10个内部概念,那么在那里大多数SQL问题时,你会做得很好。
4.使用CASE WHEN枢转数据 您很可能会看到许多要求在陈述时使用CASE WHEN的问题,这只是因为它是一种多功能的概念。如果要根据其他变量分配某个值或类,则允许您编写复杂的条件语句。...例如,如果您有一个月列,并且您希望为每个月创建一个单个列,则可以使用语句追溯数据的情况。 示例问题:编写SQL查询以重新格式化表,以便每个月有一个收入列。...同样,除了在查询/表中相同数量的列,其中不再与每个查询/表比较单个列。 6.自联结 一个SQL表自行连接自己。你可能会认为没有用,但你会感到惊讶的是这是多么常见。...请注意,使用dense_rank(),Daniel排名第3,而不是第4位()。 8.计算Delta值 另一个常见应用程序是将不同时期的值进行比较。例如,本月和上个月的销售之间的三角洲是什么?...我希望这有助于您在面试准备中 - 我相信,如果您知道这10个内部概念,那么在那里大多数SQL问题时,你会做得很好。
因此,Stratascratch的创始人Nathan Rosidi以及我觉得我认为10个最重要和相关的中级到高级SQL概念。 那个说,我们走了!...4.使用CASE WHEN枢转数据 您很可能会看到许多要求在陈述时使用CASE WHEN的问题,这只是因为它是一种多功能的概念。如果要根据其他变量分配某个值或类,则允许您编写复杂的条件语句。...例如,如果您有一个月列,并且您希望为每个月创建一个单个列,则可以使用语句追溯数据的情况。 示例问题:编写SQL查询以重新格式化表,以便每个月有一个收入列。...同样,除了在查询/表中相同数量的列,其中不再与每个查询/表比较单个列。 6.自联结 一个SQL表自行连接自己。你可能会认为没有用,但你会感到惊讶的是这是多么常见。...请注意,使用dense_rank(),Daniel排名第3,而不是第4位()。 8.计算Delta值 另一个常见应用程序是将不同时期的值进行比较。例如,本月和上个月的销售之间的三角洲是什么?
具体而言,对SQL流利的专业人士的需求日益增长,而不仅仅是在初级层面。 因此,Stratascratch的创始人Nathan Rosidi以及我觉得我认为10个最重要和相关的中级到高级SQL概念。...4.使用CASE WHEN枢转数据 您很可能会看到许多要求在陈述时使用CASE WHEN的问题,这只是因为它是一种多功能的概念。如果要根据其他变量分配某个值或类,则允许您编写复杂的条件语句。...例如,如果您有一个月列,并且您希望为每个月创建一个单个列,则可以使用语句追溯数据的情况。 示例问题:编写SQL查询以重新格式化表,以便每个月有一个收入列。...同样,除了在查询/表中相同数量的列,其中不再与每个查询/表比较单个列。 6.自联结 一个SQL表自行连接自己。你可能会认为没有用,但你会感到惊讶的是这是多么常见。...请注意,使用dense_rank(),Daniel排名第3,而不是第4位()。 8.计算Delta值 另一个常见应用程序是将不同时期的值进行比较。例如,本月和上个月的销售之间的三角洲是什么?
注意:DISTINCT 不能用于 COUNT(*) FIRST() - 返回第一个记录的值 LAST() - 返回最后一个记录的值 COUNT 函数使用注意: COUNT(column_name)...(*) FROM table_name; COUNT(DISTINCT column_name) 函数返回指定列的不同值的数目: SELECT COUNT(DISTINCT column_name)...这样,如果需要回退,可以回退到某个占位符。在 SQL 中,这些占位符称为保留点。在MariaDB、MySQL和Oracle中创建占位符,可使用SAVEPOINT语句。...游标(cursor)是一个存储在DBMS服务器上的数据库查询,它不是一条SELECT语句,而是被该语句检索出来的结果集。在存储了游标之后,应用程序可以根据需要滚动或浏览其中的数据。...这个过程用前面定义的 SELECT 语句把数据实际检索出来。 ❑ 对于填有数据的游标,根据需要取出(检索)各行。 ❑ 在结束游标使用时,必须关闭游标,可能的话,释放游标(有赖于具体的DBMS)。
使用 CASE WHEN 枢转数据 您很可能会看到许多要求在陈述时使用 CASE WHEN 的问题,这只是因为它是一种多功能的概念。如果要根据其他变量分配某个值或类,则允许您编写复杂的条件语句。...例如,如果您有一个月列,并且您希望为每个月创建一个单个列,则可以使用语句追溯数据的情况。 示例问题:编写 SQL 查询以重新格式化表,以便每个月有一个收入列。...同样,除了在查询 / 表中相同数量的列,其中不再与每个查询 / 表比较单个列。推荐:Java 面试练题宝典 ### 6. 自联结 一个 SQL 表自行连接自己。...在许多现实生活中,数据存储在一个大型表中而不是许多较小的表中。在这种情况下,可能需要自我连接来解决独特的问题。 让我们来看看一个例子。...请注意,使用 dense_rank(),Daniel 排名第 3,而不是第 4 位()。 ###v8. 计算 Delta 值 另一个常见应用程序是将不同时期的值进行比较。
SQL函数 XMLELEMENT一种格式化 XML 标记标记以包含一个或多个表达式值的函数。...在几乎所有其他上下文中,SQL 使用单引号将文字字符串括起来;它使用双引号来指定分隔标识符。因此,必须启用分隔标识符支持才能使用此功能;默认情况下启用分隔标识符。...例如,XMLELEMENT 不能在 CASE 语句的子句中执行字符转换(参见下面的示例)。XMLATTRIBUTES 函数XMLATTRIBUTES 函数只能在 XMLELEMENT 函数中使用。...在下一个示例中,提供的 NAME 关键字没有标记值:SELECT DISTINCT XMLELEMENT(NAME,Home_City,' ',Home_State) AS CityState...以下示例显示 XMLELEMENT 不能标记 CASE 语句子句中的值:SELECT XMLELEMENT("Para",Home_State, XMLELEMENT
大致分为两类:SQL Aggregate 函数计算从列中取得的值,返回一个单一的值。SQL Scalar 函数基于输入值,返回一个单一的值。...一、SQL Aggregate 函数SQL Aggregate 函数计算从列中取得的值,返回一个单一的值。...:SELECT COUNT(*) FROM table_name;COUNT(DISTINCT column_name) 函数返回指定列的不同值的数目:SELECT COUNT(DISTINCT column_name...结果集中的列名总是等于 UNION 中第一个 SELECT 语句中的列名。...如果一些网站和APP来自同一个国家,每个国家只会列出一次。UNION 只会选取不同的值。请使用 UNION ALL 来选取重复的值!
、“SQL、python这些学起来好痛苦!”我看着屏幕苦笑,数据分析岗位现在的热门程度如果要形容的话,基本就是随便抓一个微博网友都知道这个岗位了。...可以说,每个数据分析岗都需要会SQL。 我本人曾在滴滴、美团、平安科技的数据分析类岗位实习过,实习期间会大量运用sql进行取数。...写这篇文章是希望帮助还没有实战过SQL的小伙伴、或者了解一些SQL语句,但是担心自己了解的太片面的小伙伴。这篇文章主要介绍的是:如果想要面试数据分析岗位,最优先需要掌握的SQL技能是哪些呢?...读完本文,你能快速知道: (1)除了select 这种基本的语句,我最应该马上掌握的SQL语句和知识是什么? (2)面试中SQL题80%都在考察的语法是什么? (3)这些语法应该怎么使用?...本文将从三大块介绍入门SQL需要掌握的语法和知识,分别是 最基础的选择(select)和连接(join/union) 最常用的函数(distinct/group by/order by等) 一些小小的进阶技巧
领取专属 10元无门槛券
手把手带您无忧上云