--================================ --SQL 基础-->SELECT 查询 --================================= /* 一、SQL...结构化查询语言 包括DDL(数据定义语言)、DCL(数据控制语言)、 DQL(数据查询语言)、DML(数据操纵语言) 二、SQL的特点 SQL 语句不区分大小写 SQL 语句能输入一行或多行...你要用一个分号结束每个SQL 语句.(;) 三、SQL*PLUS特征: 字符日期左对齐 数字右对对齐 列名默认大写 SQL PLUS 自己的命令不需以分号“;”结束 四、SQL查询时,数字和日期类型的数据可用算术运算符...+ 加 - 减 * 乘 / 除 ( ) 用于改变运算符的优先级 五、空值 空值一般用NULL表示 一般表示未知的、不确定的值,也不是空格 一般运算符与其进行运算时,都会为空 空不与任何值相等...SELECT DISTINCT EMPNO,ENAME FROM SCOTT.EMP; --连接操作符,通过二个垂直的条描述(||),注意,日期和文字数值一定嵌入在单引号里面 SQL> SELECT EMPNO
嵌套查询是将一个select 查询放到另一个查询的where 子句中去 如:查询”xx“同学的所修课程及分数 1.先选择姓名为”xx”的同学的学号 select 学号 from 学生 where 姓名...学号 from 学生 where 姓名=”xx”); 带有in的子查询 查询与”xxx”在同一个系学习的学生的学生姓名及其院系名称 分步骤: 1.先查询 xxx 所在的系 select 院系编号 from...合并1,2 select 姓名,院系名称 from 学生,院系 where 所属院系=院系编号 and 所属院系 in (select 所属院系 from 学生 where 姓名=”xxx”) 查询选修课程名为...”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 查询的执行顺序是什么样的? 直觉上这个问题应该很好回答,毕竟我自己已经至少写了 10000 个 SQL 查询了,其中还有一些是很复杂。...SQL查询按此顺序发生 我研究了一下,执行顺序如下所示。SELECT 并不是第一个执行的,而是第五个。 ?...原文:SQL queries don’t start with SELECT
select * from emp; – 查询emp表中的所有员工的姓名、薪资、奖金 select name,sal,bonus from emp; – 查询emp表中的所有部门, 剔除重复的记录,...提示: distinct用于剔除重复值 select distinct dept from emp; where子句查询 对表中的所有记录进行筛选、过滤使用where子句,下面的运算符可以在 WHERE...(2) like // 模糊搜索,可配合 “%” 和 “_” 等符号。 (3) “%” //表示通配,表示0或多个字符。 (4) 下划线 //表示一个字符串。...(sal+bonus)>3000; -- 或 select name, sal+bonus as 总薪资 from emp where (sal+bonus)>3000; 提示:as用于定义别名(仅在查询的结果中作为列的表头显示...4、avg() – 求所查询记录中指定列的平均值 – 查询emp表中最高薪资 select max(sal) as 最高薪资 from emp; – 查询emp表中最高总薪资 select max(
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开始的(实际上本文只是关注SELECT查询,而不是INSERT或其它别的什么)。 但是!...昨天我正在做窗口函数的解释说明,并且我发现自己在谷歌上搜索“你能根据窗口函数的结果进行过滤吗”。比如 — 你能在WHERE、HAVING或者其它地方过滤窗口函数的结果吗?...但这让我想到了一个更大的问题 — SQL查询的实际运行顺序是什么? 这是我凭直觉就知道的事情(“我肯定知道!我已经编写了至少10000个SQL查询,其中一些非常复杂!)...1、SQL查询按此顺序进行 这就是我查找到的顺序!...“sql查询按此顺序发生/运行”更准确的表达方式,但我还没想出来。)
很多 SQL 查询都是以 SELECT 开始的。...不过,最近我跟别人解释什么是窗口函数,我在网上搜索”是否可以对窗口函数返回的结果进行过滤“这个问题,得出的结论是”窗口函数必须在 WHERE 和 GROUP BY 之后,所以不能”。...于是我又想到了另一个问题:SQL 查询的执行顺序是怎样的? 好像这个问题应该很好回答,毕竟自己已经写了上万个 SQL 查询了,有一些还很复杂。但事实是,我仍然很难确切地说出它的顺序是怎样的。...SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...混合因素:列别名 有很多 SQL 实现允许你使用这样的语法: 从这个语句来看,好像 GROUP BY 是在 SELECT 之后执行的,因为它引用了 SELECT 中的一个别名。
一、SELECT语句 使用select查询表数据,必须至少给出两条信息——想选择什么,以及从什么地方选择。 #1.查询单个列: select id from stu; ?...结束SQL语句 多条SQL语句以分号(;)分隔。 SQL语句和大小写 SQL语句不区分大小写,SELECT与select是相同的。同样,写成Select也没有关系。...#2.查询多个列:查询学生表的id,name两列的值 select id,name from stu; ? 在select关键字后给出多个列名,列名之间以逗号分隔,最后一个列名后不加逗号。...#3.查询所有列:查询学生表所有列的值 select * from stu; ? 使用*通配符 一般,除非确实需要表中的每个列,否则最好别使用*通配符。...不能部分使用DISTINCT DISTINCT关键字应用于所有列而不仅是前置它的列,除非指定的两个列都不同,否则所有行都将被检索出来。
大家好,我是狼王,一个爱打球的程序员 大家平时和SQL语句打交道的时间肯定不少,有写过简单SQL的,也有为很复杂的业务逻辑的SQL绞尽脑汁的,那我在这里问下大家一个简单的问题:那你知道SQl语句的查询顺序是怎么样的吗...当我刚看到这个问题的时候,我的内心是这样的 这个问题应该很好回答,毕竟自己已经写了无数个 SQL 查询语句了,有一些还很复杂的。还装不了这个逼了??..._2; 的结果一致,都是表示求笛卡尔积;用于直接计算两个表笛卡尔积,得到虚拟表VT1,这是所有select语句最先执行的操作,其他操作是在这个表上进行的,也就是from操作所完成的内容 on: 从VT1...,having,所用到的列必须包含在group by条件中,没有出现的需要用聚合函数; having: 筛选分组后的数据,得到VT6表; select: 返回列得到VT7表; distinct: 用于去重得到...但是,数据库引擎并不一定严格按照这个顺序执行 SQL 查询,因为为了更快地执行查询,它们会做出一些优化,这些问题会在下方进行解释↓↓↓。 SQL中的别名会影响SQL执行顺序么?
当我们数据中含有中文,或我们想要Select出中文,当我去查询的时候默认情况下是无法搜索、无法显示的。...[PersonalDetails] where ChineseName = '成龙' 这样是无法搜索出成龙的。...同理,以下查询也是无效的 DECLARE @date1 DATE, @date2 DATE, @date3 DATE, @date4 DATE; SET @date1=GETDATE(); SET @...((Select CurrentAcademicYear from SchoolDataManagement)+1),'-03-01'); SET @date4=CONCAT(((Select...ELSE IF @date1>@date3 AND @date1 <@date4 SELECT '第二学期' as SemesterName; 如果你SELECT ‘第一学期’ 即可发现,’第一学期
SQL通配符字符 通配符字符用于替代字符串中的一个或多个字符。通配符字符与LIKE运算符一起使用。LIKE运算符用于在WHERE子句中搜索列中的指定模式。...示例 返回所有以字母 'a' 开头的客户: SELECT * FROM Customers WHERE CustomerName LIKE 'a%'; 通配符字符 符号 描述 % 表示零个或多个字符 _...示例 返回以模式 'es' 结尾的所有客户: SELECT * FROM Customers WHERE CustomerName LIKE '%es'; 示例 返回包含模式 'mer' 的所有客户:...SELECT * FROM Customers WHERE CustomerName LIKE '%mer%'; 使用 _ 通配符 通配符表示一个单个字符。...的客户: SELECT * FROM Customers WHERE CustomerName LIKE '_r%'; 没有通配符 如果没有指定通配符,短语必须精确匹配才能返回结果。
作者丨Julia Evans 译者丨无明 很多 SQL 查询都是以 SELECT 开始的。...不过,最近我跟别人解释什么是窗口函数,我在网上搜索”是否可以对窗口函数返回的结果进行过滤“这个问题,得出的结论是”窗口函数必须在 WHERE 和 GROUP BY 之后,所以不能”。...于是我又想到了另一个问题:SQL 查询的执行顺序是怎样的? 好像这个问题应该很好回答,毕竟自己已经写了上万个 SQL 查询了,有一些还很复杂。但事实是,我仍然很难确切地说出它的顺序是怎样的。...1 SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。...但数据库引擎并不一定严格按照这个顺序执行 SQL 查询,因为为了更快地执行查询,它们会做出一些优化,这些问题会在以后的文章中解释。
很多 SQL 查询都是以 SELECT 开始的。...不过,最近我跟别人解释什么是窗口函数,我在网上搜索”是否可以对窗口函数返回的结果进行过滤“这个问题,得出的结论是”窗口函数必须在 WHERE 和 GROUP BY 之后,所以不能”。...于是我又想到了另一个问题:SQL 查询的执行顺序是怎样的? 好像这个问题应该很好回答,毕竟自己已经写了上万个 SQL 查询了,有一些还很复杂。但事实是,我仍然很难确切地说出它的顺序是怎样的。...SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...但数据库引擎并不一定严格按照这个顺序执行 SQL 查询,因为为了更快地执行查询,它们会做出一些优化,这些问题会在以后的文章中解释。
1.1 概述 在 SQL 语言中,一个 SELECT-FROM-WHERE 语句称为一个查询块。...外部的 SELECT 查询语句,称为主查询或外查询。...后的子查询 1.3.1 查询每个部门员工个数 mysql> select dept.*, -> ( select count(*) from emp where emp.dept_id = dept.id...1.4.1 查询每个部门的平均工资 mysql> select avg(salary) as avg, dept_id from emp group by dept_id; +------------...④ select 后面的子查询,仅仅支持标量子查询,即结果集只有一行一列。 ⑤ from 后面的子查询是将子查询的结果集充当一张临时表,要求必须起别名,否者这个表找不到。
1.1 分组查询 1.1.1 语法 # where 和 having 可以省略 SELECT col_name, group_function, ··· FROM tb_name [WHERE where_condition...说明 max( ) 查询指定列的最大值 min( ) 查询指定列的最小值 count( ) 统计查询结果的行数 sum( ) 求和,返回指定列的总和 avg( ) 求平均值,返回指定列数据的平均值...④ limit 为 MySQL 的 “方言” 在其他 SQL 中不一定能用。...1.4.1 语法 # 可以省略某些查询,但是顺序不能改变 select * from tb_name where where_condition group by group_expression having...400 的数据中 number 大于 3 的数据并按 name 分组,按照每组数据条数倒序,从 0 号数据开始查询 3 条数据 mysql> select *, count(*) from mydata
作者丨Julia Evans 译者丨无明 很多 SQL 查询都是以 SELECT 开始的。...不过,最近我跟别人解释什么是窗口函数,我在网上搜索”是否可以对窗口函数返回的结果进行过滤“这个问题,得出的结论是”窗口函数必须在 WHERE 和 GROUP BY 之后,所以不能”。...于是我又想到了另一个问题:SQL 查询的执行顺序是怎样的? 好像这个问题应该很好回答,毕竟自己已经写了上万个 SQL 查询了,有一些还很复杂。但事实是,我仍然很难确切地说出它的顺序是怎样的。...1 SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...原文链接: https://jvns.ca/blog/2019/10/03/sql-queries-don-t-start-with-select/
测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 针对数据表里面的每条记录,select查询语句叫做数据查询语言...栗子一:查询表的所有字段 select * from yytest; ?...* 栗子二:查询表的指定字段 # 查询表指定的字段(全部) select id,username,sex,birth,department,address,poloyy6 from yyTest; ?...# 查询指定字段 select id,username from yyTest; ?...知识点 可以指定表的所有字段,然后更改字段顺序, 这种查询所有字段的写法比较灵活 也可以只指定某几个字段,多个字段用 隔开 , 拓展一个知识点,常见关键字的执行顺序 有哪些常见关键字 select distinct
很多 SQL 查询都是以 SELECT 开始的。...不过,最近我跟别人解释什么是窗口函数,我在网上搜索”是否可以对窗口函数返回的结果进行过滤“这个问题,得出的结论是”窗口函数必须在 WHERE 和 GROUP BY 之后,所以不能”。...于是我又想到了另一个问题:SQL 查询的执行顺序是怎样的? 这个问题好像应该很好回答,毕竟自己已经写了上万个 SQL 查询了,有一些还很复杂。但事实是,我仍然很难确切地说出它的顺序是怎样的。...SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...但数据库引擎并不一定严格按照这个顺序执行 SQL 查询,因为为了更快地执行查询,它们会做出一些优化,这些问题会在以后的文章中解释。
1.1 基础查询 1.1.1 查询所有列 ☞ 语法 # " * " 代表返回表中所有字段的数据 select * from tb_name; ☞ 示例 mysql> select * from student...1.1.2 查询指定字段 ☞ 语法 # tb_name 表中需要查询的字段 select field_1, field_2 from tb_name; ☞ 示例 mysql> select name,...☞ 语法 # 用中文名代替字段名,其中 as 可以省略 select col_name [as] chinese_name from tb_name; ☞ 示例 mysql> select num as...1.2 条件查询 1.2.1 语法 # 条件查询 select * from 表名 where 条件; ☞ 注意 关键字 where 后面跟上一个或者多个条件,条件是对前面数据的过滤,只有满足 where...或者 IS NOT NULL,其他查询运算符对 NULL 值无效 ② 建议创建表的时候,尽量设置表的字段不能为空,给字段设置一个默认值。
select查询 distinct取消重复 create table student( id int not null default 1, name varchar(20) not null default...查询表中所有学生的姓名和对应的英语成绩 过滤表中重复的数据 distinct 要查询的记录,每个字段都相同,才会去重 -- select 查询 select * from student; select...) > 200; -- 查询math>60 并且 english > 90 select * from student where `math`>60 and `english`>90; -- 查询总分大于...and `name` like 'y%'; -- 查询English在80到90分之间的 select * from student where english between 80 and 90;...-- 闭区间 select * from student where english >=80 and english <= 90; 使用order by子句排序查询 升序:Ascending order