--================================ --SQL 基础-->SELECT 查询 --================================= /* 一、SQL...结构化查询语言 包括DDL(数据定义语言)、DCL(数据控制语言)、 DQL(数据查询语言)、DML(数据操纵语言) 二、SQL的特点 SQL 语句不区分大小写 SQL 语句能输入一行或多行...关键字不能整行缩写或分离 子句通常被放置在分开的行上 缩进可提高可读性 在SQL 开发工具,SQL 语句能选择分号结束(;) .当你运行多个SQL 语句的时候,需要分号 在SQL*Plus中,...你要用一个分号结束每个SQL 语句.(;) 三、SQL*PLUS特征: 字符日期左对齐 数字右对对齐 列名默认大写 SQL PLUS 自己的命令不需以分号“;”结束 四、SQL查询时,数字和日期类型的数据可用算术运算符...SELECT DISTINCT EMPNO,ENAME FROM SCOTT.EMP; --连接操作符,通过二个垂直的条描述(||),注意,日期和文字数值一定嵌入在单引号里面 SQL> SELECT EMPNO
查询所有 SELECT * FROM `表名`; 查询指定字段 SELECT `字段名1`,`字段名2`......FROM `表名`; 查询符合约束条件的字段 SELECT `字段名1`,`字段名2`......FROM `表名` WHERE 约束条件; 模糊查询: 占位符 % 任意长度的任意内容 _ 一个长度的任意内容 SELECT `字段名1`,`字段名2`......FROM `表名` WHERE `字段名` LIKE '%或_配合关键词'; 查询符合约束条件的字段,按照指定字段排序 ASC 升序 小 -- 大 默认值,可以不写 ESC 降序 大 -- 小 SELECT...12 T1003 12 T1004 14 T1006 12 T1007 12 查询数据库中的某个字段 SELECT * FROM information_schema.columns WHERE column_name
以下是我写的SQL语句: SELECT DATE_FORMAT( createtime, "%Y-%m-%d" ) cr, product, SUM(price) total FROM orders GROUP...BY DATE_FORMAT(createtime, "%Y-%m-%d"), product 查询结果例如以下: 这个结果确实满足了我的需求,可是存在一个问题。...假设查询结果是以下这个样子,我想看起来会舒服得多: 对于怎样直接从表中查询出这种结果,我是一点想法都没有,可是,我却知道怎样从上一个SQL语句的查询结果中查询从而得到想要的结果。...以下是我写的SQL语句: SELECT origintable.cr, SUM(CASE WHEN origintable.product = "电动车" THEN origintable.total...DATE_FORMAT(createtime, "%Y-%m-%d"), product) AS origintable GROUP BY origintable.cr 假设大家想亲自试一试,能够用以下的SQL
好吧,显然很多SQL查询都是从SELECT开始的(实际上本文只是关注SELECT查询,而不是INSERT或其它别的什么)。 但是!...我已经编写了至少10000个SQL查询,其中一些非常复杂!),但我很难真正地准确说出顺序是什么。 1、SQL查询按此顺序进行 这就是我查找到的顺序!...“sql查询按此顺序发生/运行”更准确的表达方式,但我还没想出来。)...2、图解此图有助于你做出回答 此图是关于SQL查询的语义的 — 你可以通过它,对给定查询将返回什么结果进行推理,并回答如下问题: 我能在一个GROUP BY的结果上执行WHERE么?...所以: 当你只想了解哪些查询是有效的,以及如何推理给定查询的结果时,可以使用此图。 你不应该使用此图来解释查询性能或任何有关索引的事情,那是一个复杂得多的问题,涉及更多变量。
嵌套查询是将一个select 查询放到另一个查询的where 子句中去 如:查询”xx“同学的所修课程及分数 1.先选择姓名为”xx”的同学的学号 select 学号 from 学生 where 姓名...学号 from 学生 where 姓名=”xx”); 带有in的子查询 查询与”xxx”在同一个系学习的学生的学生姓名及其院系名称 分步骤: 1.先查询 xxx 所在的系 select 院系编号 from...学生 where 姓名=”xxx”; 假如结果为:”yyy”; 2.查询 “yyy”的名称及该系学习的学生 select 姓名,院系名称 from 学生,院系 where 所属院系 = 院系编号 and...”xx”的学生学号和姓名 1,先从课程表中查询课程名为”xx”的课程编号 as: select 课程编号 from 课程表 where 课程名=”xx” 2.从成绩表中查询学生学号,通过1中的课程编号...as: select 学生学号 from 成绩 where 课程编号 in(1) 3.从学生表中查询学生学号,姓名通过2中的学号 最后合并为 select 学生学号,姓名 from 学生表 where
很多 SQL 查询确实以 SELECT 开始(本文仅涉及 SELECT 查询,而不涉及 INSERT 或其他内容)。...不过,我在网上搜索 ‘是否可以对窗口函数返回的结果进行过滤’ 这个问题,或者说可以在 WHERE、HAVING 或其他中过滤窗口函数的结果吗?...SQL查询按此顺序发生 我研究了一下,执行顺序如下所示。SELECT 并不是第一个执行的,而是第五个。 ?...实际上,数据库引擎并不一定按照这个顺序执行查询,因为为了使查询运行更快,实现了一系列优化。所以: 当我们只想了解哪些查询是合法的以及如何推理给定查询的返回结果时,可以参考上图。...查询可能不会按上述顺序运行 实际上,数据库引擎并不一定会按照 JOIN、WHERE、GROUP BY 的顺序来执行查询,因为它们会进行一系列优化,只要重新排序不会改变查询的结果,它们就会对命令进行重新排序以使查询运行得更快
select name,sal,bonus from emp where sal>3000 and bonus<600; 排序查询 对查询的结果进行排序使用 order by关键字。...emp表中薪资最高的员工姓名, 下面的写法是错的: select name, max(sal) from emp;–结果是错的 – 正确的查询: select name, sal from emp...多表连接查询 连接查询:将两张或者两张以上的表,按照指定条件查询,将结果显示在一张表中。 多张表查询的语法: select... from A, B... where......上面小写的a和b就是A和B表的别名: – 查询部门和员工两张表 select * from dept,emp; 上面查询的结果中存在大量错误的数据, 如果想正确显示部门及部门对应的员工,可以通过where...子查询 所谓的子查询,其实就是将一个查询得出的结果,作为另外一个查询的条件。 格式: select... from... where...
SELECT 关键字 SQL的SELECT语句用于从数据库中选择数据。SELECT语句的基本语法如下: SELECT column1, column2, ......SELECT DISTINCT 关键字 SQL的SELECT DISTINCT语句用于选择表中的不同(唯一)值。...在这种情况下,您可以使用子查询来达到相同的目的。 SQL WHERE 关键字 SQL的WHERE子句用于筛选数据库表中的记录。它允许您提取只满足指定条件的记录。...运算符的使用取决于您的筛选需求,可以根据需要进行选择。 ORDER BY 关键字 SQL的ORDER BY关键字用于对结果集进行排序,您可以按升序(ASC)或降序(DESC)进行排序。...BY关键字使您可以以不同的方式对查询结果进行排序,以满足不同的需求。
很多 SQL 查询都是以 SELECT 开始的。...于是我又想到了另一个问题:SQL 查询的执行顺序是怎样的? 好像这个问题应该很好回答,毕竟自己已经写了上万个 SQL 查询了,有一些还很复杂。但事实是,我仍然很难确切地说出它的顺序是怎样的。...SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...可以对窗口函数返回的结果进行过滤吗?...混合因素:列别名 有很多 SQL 实现允许你使用这样的语法: 从这个语句来看,好像 GROUP BY 是在 SELECT 之后执行的,因为它引用了 SELECT 中的一个别名。
大家好,又见面了,我是你们的朋友全栈君。 SQL连接查询和嵌套查询详解 连接查询 若一个查询同时涉及两个或两个以上的表,则称之为连接查询。...这两个表之间的联系是通过公共属性Sno实现的。 考虑下列等值连接查询语句 SELECT Student.....* FEOM Student,Study WHERE Student.Sno=Study.Sno /*将Student与Study中同一学生的元祖连接起来*/ 得到的结果: 我们发现,上述查询语句按照把两个表中学号相等的元祖连接起来...结果: 3.自身连接查询 当查询的结果涉及同一个表中两个或以上的列时,考虑用自身连接查询。....Pcno=C2.Cno /*两个Course表的连接*/ 结果: 4、外连接查询: 分为左外连接,右外连接, 左外连接:根据左表的记录,在被连接的右表中找出符合条件的记录与之匹配
大家好,我是狼王,一个爱打球的程序员 大家平时和SQL语句打交道的时间肯定不少,有写过简单SQL的,也有为很复杂的业务逻辑的SQL绞尽脑汁的,那我在这里问下大家一个简单的问题:那你知道SQl语句的查询顺序是怎么样的吗...当我刚看到这个问题的时候,我的内心是这样的 这个问题应该很好回答,毕竟自己已经写了无数个 SQL 查询语句了,有一些还很复杂的。还装不了这个逼了??...但是,数据库引擎并不一定严格按照这个顺序执行 SQL 查询,因为为了更快地执行查询,它们会做出一些优化,这些问题会在下方进行解释↓↓↓。 SQL中的别名会影响SQL执行顺序么?...数据库很可能不按正常顺序执行查询(优化) 在实际当中,数据库不一定会按照 JOIN、WHERE、GROUP BY 的顺序来执行查询,因为它们会进行一系列优化,把执行顺序打乱,从而让查询执行得更快,只要不改变查询结果...= '狼王' 如果只需要找出名字叫狼王学生信息,那就没必要对两张表的所有数据执行左连接,在连接之前先进行过滤,这样查询会快得多,而且对于这个查询来说,先执行过滤并不会改变查询结果。
未排序数据 如果没有明确排序查询结果,可能会发现显示输出的数据顺序与原表不同,返回的数据的顺序没有特殊意义,可能是数据被添加到表中的顺序,也可能不是,只要返回相同数目的行就是正常的。...结束SQL语句 多条SQL语句以分号(;)分隔。 SQL语句和大小写 SQL语句不区分大小写,SELECT与select是相同的。同样,写成Select也没有关系。...#2.查询多个列:查询学生表的id,name两列的值 select id,name from stu; ? 在select关键字后给出多个列名,列名之间以逗号分隔,最后一个列名后不加逗号。...#5.1 限制结果(limit分页):查询学生表前4行的学生ID select id from stu limit 4; ?...#5.2 限制结果(limit m,n:从行m开始往后n行,第1行的m为0):查询学生表倒数三个学生的ID select id from stu limit 1,3; ?
其中distinct针对的是查询结果的整条记录而言的。...,name from my_student;结果是一样的。...②[where 字句]:where是唯一一个从磁盘开始拿数据的时候就开始进行判断的条件,从磁盘取出一条记录,开始进行where判断,判断结果如果成立,那么取出结果保存到内存,否则放弃。...单子段分组: selectc_id,count(*),max(height),min(height),avg(height),sum(age) from my_studentgroup by c_id ; sql...select * from my_student order by c_id,sex; ⑥[limit 子句]:限制结果的数量。
很多 SQL 查询都是以 SELECT 开始的。...于是我又想到了另一个问题:SQL 查询的执行顺序是怎样的? 好像这个问题应该很好回答,毕竟自己已经写了上万个 SQL 查询了,有一些还很复杂。但事实是,我仍然很难确切地说出它的顺序是怎样的。...SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...可以对窗口函数返回的结果进行过滤吗?...而且对于这个查询来说,先执行过滤并不会改变查询结果。
作者丨Julia Evans 译者丨无明 很多 SQL 查询都是以 SELECT 开始的。...于是我又想到了另一个问题:SQL 查询的执行顺序是怎样的? 好像这个问题应该很好回答,毕竟自己已经写了上万个 SQL 查询了,有一些还很复杂。但事实是,我仍然很难确切地说出它的顺序是怎样的。...1 SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。...可以对窗口函数返回的结果进行过滤吗?...'mr darcy' 如果只需要找出名字叫“mr darcy”的猫,那就没必要对两张表的所有数据执行左连接,在连接之前先进行过滤,这样查询会快得多,而且对于这个查询来说,先执行过滤并不会改变查询结果。
作者丨Julia Evans 译者丨无明 很多 SQL 查询都是以 SELECT 开始的。...于是我又想到了另一个问题:SQL 查询的执行顺序是怎样的? 好像这个问题应该很好回答,毕竟自己已经写了上万个 SQL 查询了,有一些还很复杂。但事实是,我仍然很难确切地说出它的顺序是怎样的。...1 SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...可以对窗口函数返回的结果进行过滤吗?...只要不改变查询结果。
很多 SQL 查询都是以 SELECT 开始的。...于是我又想到了另一个问题:SQL 查询的执行顺序是怎样的? 这个问题好像应该很好回答,毕竟自己已经写了上万个 SQL 查询了,有一些还很复杂。但事实是,我仍然很难确切地说出它的顺序是怎样的。...SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...可以对窗口函数返回的结果进行过滤吗?...= 'mr darcy' 如果只需要找出名字叫“mr darcy”的猫,那就没必要对两张表的所有数据执行左连接,在连接之前先进行过滤,这样查询会快得多,而且对于这个查询来说,先执行过滤并不会改变查询结果
测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 针对数据表里面的每条记录,select查询语句叫做数据查询语言...where group by having order by limit 这篇先简单入个门 最简单的查询栗子 栗子一:查询表的所有字段 select * from yytest; ?...知识点 通配符,代表查询所有字段 * 使用 时,只能按照数据表中字段的顺序进行排列,不能自定义字段排序 * 建议:不知道所需查询的列名称时,才用 ,否则获取不需要的列数据会降低查询和所使用应用程序的效率...* 栗子二:查询表的指定字段 # 查询表指定的字段(全部) select id,username,sex,birth,department,address,poloyy6 from yyTest; ?...知识点 可以指定表的所有字段,然后更改字段顺序, 这种查询所有字段的写法比较灵活 也可以只指定某几个字段,多个字段用 隔开 , 拓展一个知识点,常见关键字的执行顺序 有哪些常见关键字 select distinct
getAppletBWareOrderByDepotId(@Param("allDepotId") List allDepotId,@Param("selectField") String selectField);xml代码 select...id="getAppletBWareOrderByDepotId" resultType="com.ellassay.x2.sync.entity.X2DRetailEntity"> select...#{ids} and setdepot_id = original_depot_id and bills_tag IS NOT NULL select
查询操作是SQL语言中很重要的操作,我们今天就来详细的学习一下。 一、数据查询的语句格式 SELECT [ALL|DISTINCT] [, ....]...细化聚集函数的作用对象 未对查询结果分组,聚集函数将作用于整个查询结果 对查询结果分组后,聚集函数将分别作用于每个组 作用对象是查询的中间结果表 按指定的一列或多列值分组,值相等的为一组 合计函数...: SELECT NAME,2020-Birth FROM Student; 得道如下的查询结果: Name 2020-Birth 李勇 21 刘晨 23 王敏 24 张立 22 在查询中添加新的字符串列...) 函数返回指定列的值的数目(NULL 不计入): SELECT COUNT(column_name) FROM table_name SQL COUNT(*) 语法 COUNT(*) 函数返回表中的记录数...SQL AVG() 语法 SELECT AVG(column_name) FROM table_name 例 计算1号课程的学生平均成绩。
领取专属 10元无门槛券
手把手带您无忧上云