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

SQL语句where 和 on 的区别

最近面试时候碰到一道题,关于数据库左连接和内连接中and和where的区别,网上看了看资料,加深一下印象,大家也可以看看。...2、where条件是在临时表生成好后,再对临时表进行过滤的条件。...在使用inner join内连接时,不管是对左表还是右表进行筛选,on and和on where都会对生成的临时表进行过滤。...join过程可以这样理解:首先两个表做一个笛卡尔积,on后面的条件是对这个笛卡尔积做一个过滤形成一张临时表,如果没有where就直接返回结果,如果有where就对上一步的临时表再进行过滤。...where的过滤作用就出来了,右连接的原理是一样的。到这里就真相大白了:inner join中on和where没区别,右连接和左连接就不一样了。 本文转载自: SQL语句where和 on的区别?

3K20

WHERE语句

WHERE语句 SELECT语句用于选取字段,WHERE语句用于过滤条件,两者结合使用可以查找到符合过滤条件的记录。...WHERE语句使用谓词表达式,对于列应用在谓词操作符上的情况,稍后我们将进行讨论。有几种谓词表达式可以使用AND和OR相连接。当谓词表达式计算结果为true时,相应的行将被保留并输出。...注:WHERE后面是不可以使用别名的,如果想使用别名,那可以使用嵌套语句去查询。 1.谓词操作符 下面这些谓词操作符可以用于JOIN... ON和HAVING语句中。...SQL使用=,而不是== AB,A!...NULL则返回TRUE;反之返回FLASE A IS NOT NULL 所有数据类型 如果A不等于NULL则返回TRUE;反之返回FLASE A [NOT] LIKE B STRING 类型 B是一个SQL

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

sql语句where与having的区别

Where 是一个约束声明,使用Where约束来自数据库的数据,Where是在结果返回之前起作用的,Where中不能使用聚合函数。...在查询过程中聚合语句(sum,min,max,avg,count)要比having子句优先执行。而where子句在查询过程中执行优先级高于聚合语句。 下面用一个例子进一步说明问题。...PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=7 DEFAULT CHARSET=utf8; 例1:要查找平均工资大于3000的部门 则 sql...一来,我们要使用聚合语句 avg ;二来,我们要对聚合后的结果进行筛选( average > 3000 ),因此使用 where 会被告知 sql 有误。...例2:要查询每个部门工资大于3000的员工个数 sql语句应为: select deparment, count(*) as c from salary_info where salary >

1.5K20

Mysql常用sql语句(8)- where 条件查询

测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 条件查询应该是作为测试平时用到最多的关键字了!!...它可以用来指定查询条件,减少不必要的查询时间 where的语法格式 WHERE 查询条件 五种查询条件 比较运算符、逻辑运算符 between and 关键字 is null 关键字 in、exist...= 1; select * from yyTest where height > 170; select * from yyTest where height >= 175; select * from...yyTest where age < 20; select * from yyTest where age <= 20; 多条件的查询栗子 多条件的查询都需要使用逻辑运算符,下面的栗子比较简单不展开描述...; select * from yyTest where height 175; select * from yyTest where height < 165 ||

1.2K20

「SAP ABAP」OPEN SQL(八)【WHERE语句大全】

在学习工作中,我通常使用偏后端的开发语言ABAP,SQL进行任务的完成,对SAP企业管理系统,SAP ABAP开发和数据库具有较深入的研究。...案例演示   下面给出四段以SFLIGHT数据库表为基准的示例代码,详细讲解了ABAP OPEN SQL中简单WHERE子句的应用,仅供参考: PS:为了简便,下面的语法都基于OPEN SQL的新语法...案例演示   下面给出三段以SFLIGHT数据库表为基准的示例代码,详细讲解了ABAP OPEN SQLWHERE子句逻辑运算符的应用,仅供参考: PS:为了简便,下面的语法都基于OPEN SQL的新语法...FROM table_name WHERE field_name IN (['value1', 'value2', 'value3' | 子查询语句])....ENDLOOP. ---- 写在最后的话   本文花费大量时间介绍了OPEN SQLWHERE语句大全,希望能帮助到各位小伙伴,码文不易,还望各位大佬们多多支持哦,你们的支持是我最大的动力!

1.1K20

数据库的查询语句_数据库select from where

- 会出现插入数据有问题,中文错误 这是因为: 1 、 在dos窗口中,默认的编码格式gbk,而mysql服务器软件使用的编码utf8 2、在dos窗口输入一个指令,模糊查询当前mysql数据库中所有带有...character_set_results = gbk ; 5、改动完成,才能在dos窗口中临时插入数据可以支持中文的; 6、这些修该都是临时修改,下次使用的时候还需重新设置 二、数据库的一些查询语句...=20; SELECT * FROM student3 WHERE age 20; -- where 后面可以跟多个人 条件,并列或者的条件 -- 可以使用逻辑的双与&&和双或|| -- 查询学生年龄...student3 WHERE age=18 OR age=20 OR age=45 -- 当有多个或的关系的时候,可以使用in 集合语句----where 字段名称 in(值1,值2,值3);...','30','女','西安',89,95); -- SELECT * FROM student3 ORDER BY math DESC,english ASC; 总结:今日查询语句比较多,只能通过练习来熟悉和掌握

1.4K10

为什么SQL语句Where 1=1 and在SQL Server中不影响性能

最近一个朋友和我探讨关于Where 1=1 and这种形式的语句会不会影响性能。最后结论是不影响。     虽然结论正确,但对问题的认识却远远没有解决问题的根本。...实际上在T-SQL语句的书写过程中经常犯得错误就是得出一个很窄的结论,然后教条式的奉若圣经,对于T-SQL领域来说,在网上经常可以看到所谓的优化守则,随便在网上搜了一些摘录如下: 不要有超过5个以上的表连接...举个例子,平常有人对你说你有点肾虚,我想你的第一反应肯定是想办法捍卫男人的尊严了,但如果你去医院检查医生这么说,那你可能就会一脸虔诚的求教如何补了:-),那举上述摘录的语句例子:1)少用子查询,如果在SQL...而在SQL Server领域,T-SQL语句到查询结果返回需要经历一个完整的周期,如图1:     图1.T-SQL生命周期     因此,在关系数据库领域,SQL语句的写法只是一个抽象的逻辑,而不是像编程语言那样直接的实现...比如语句select * from table where a=1 and b=2 这个语句SQL Server估计的行数会是:     a列的选择率*b列的选择率*表中采样的总行数     因此,当

2K30

MySQL数据库SQLwhere条件提取

例如,考虑以下的⼀条SQL:select * from t1 where b >= 2 and b 1 and d != 4 and e !...= 'a'; ⼀条⽐较简单的SQL,⼀⽬了然就可以发现where条件使⽤到了[b,c,d,e]四个字段,⽽t1表的idxt1bcd索引,恰好使⽤了[b,c,d]这三个字段,那么⾛idxt1bcd索引进⾏...接下来,让我们抛弃数据库的思想,直接思考这条SQL的⼏个关键性问题: 此SQL,覆盖索引idxt1bcd上的哪个范围? 起始范围:记录[2,2,2]是第⼀个需要检查的索引项。...在理解以上的问题解答的基础上,做⼀个抽象,可总结出⼀套放置于所有SQL语句⽽皆准的where查询条件的提取规则: 所有SQLwhere条件,均可归纳为3⼤类 • Index Key (First Key...Index Key/Index Filter/Table Filter⼩结 SQL语句中的where条件,使⽤以上的提取规则,最终都会被提取到Index Key (First Key & Last Key

2.3K10

数据库SQL语句大全——最常用的SQL语句

product WHERE market_price>800 价格在800到10000之间 SELECT pname,market_price FROM product WHERE market_price...= 不等于 < 小于 <= 小于等于 > 大于 >= 大于等于 BETWEEN 在指定的两个值之间 数据过滤: 组合where语句 and操作符(同时符合where后面的条件) SELECT pname...,market_price FROM product WHERE market_price>1000 AND is_hot=0 or操作符(只需要符合where后面的一个条件的结果都会显示出来) SELECT...,market_price FROM product WHERE market_price LIKE '_99' 正则表达式搜索 基本字符串匹配 SELECT pname FROM product WHERE...SELECT语句的执行顺序 SELECT 要返回的列或表达式 是 FROM 从中检索数据的表 仅在从表选择数据时使用 WHERE 行级过滤 否 GROUP BY 分组说明 仅在按组计算聚集时使用 HAVING

2.9K30

SQL语句中 left join 后用 on 还是 where,区别大了!

运行sql : select * from student s left join class c on s.classId=c.id order by s.id 运行sql : select * from...s left join class c on s.classId=c.id and c.name="三年级三班" order by s.id 数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表...where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。...where 条件: tab2.name=’AAA’ 第二条SQL的过程: 1、中间表on条件: tab1.size = tab2.size and tab2.name=’AAA’ (条件不为真也会返回左表中的记录...而inner jion没这个特殊性,则条件放在on中和where中,返回的结果集是相同的。

42820

MySQL 复杂 where 语句分析

在《MySQL 常见语句加锁分析》一文中,我们详细讲解了 SQL 语句的加锁原理并具体分析了大部分的简单 SQL 语句,但是实际业务场景中 SQL 语句往往及其复杂,包含多个条件,此时就需要具体分析SQL...我们可以直接使用 explain 或者 optimizer_trace 来分析 SQL 语句执行使用了哪些索引,具体使用可以看本系列文章的前两篇文章。...但是我们也需要了解具体 Where 语句的条件的拆分和使用,即复杂 Where 条件是如何生效的,用何登成大神的原话,就是: 给定一条SQLwhere条件中的每个子条件,在SQL执行的过程中有分别起着什么样的作用...Index Key 和 Table Filter 基于上述表,我们具体分析一下如下拥有复杂 Where 条件的 SQL 语句。 ?...上述 SQL 语句Where 条件使用了两个索引,分别是二级唯一索引 ISBN 和二级非唯一索引 Author。

1.7K30

SQL命令 WHERE(一)

如果谓词包含除法,并且数据库中有任何值可以生成值为零或NULL的除法,则不能依赖求值顺序来避免被零除法。 相反,使用CASE语句来抑制风险。 WHERE子句可以指定包含子查询的条件表达式。...因此,动态SQL不能在WHERE子句比较中使用%List数据。 要引用结构化列表数据,请使用%INLIST谓词或FOR SOME %ELEMENT谓词。...例如,WHERE %NOINDEX Age >= 1。 离群值的谓词条件 如果动态SQL查询中的WHERE子句选择了一个非空的离群值,可以通过将离群值文字括在双括号中来显著提高性能。...要最优地选择这个值,应该指定WHERE Home_State=(('MA'))。 在嵌入式SQL或视图定义中不应使用此语法。 在嵌入式SQL或视图定义中,总是使用离群值选择,不需要特殊编码。...动态SQL查询中的WHERE子句会自动针对空离群值进行优化。 例如,WHERE FavoriteColors IS NULL这样的子句。

2.9K20

讲解SQL数据库语句

前言 大家好,我是 Vic,今天给大家带来讲解SQL数据库语句的概述,希望你们喜欢 数据库语句 create database teach; use teach; create table `teach...sex='女生' and S# in(select S# from SC where C#='C4'); 脏读:到达广州结果走到一半 不可重复读:一样的语句,可能被人复读 幻读:同样两条语句,你在用别人也在用...光标CLOSE语句 CLOSE cursor_name 数据库技术 ? 示意图 ?...SQL的主要功能 (1)数据定义功能。 (2)数据操纵功能。 (3)数据控制功能。 数据库由3种类型组成:系统数据库、用户数据库数和数据库快照。...❤️ 总结 本文讲了讲解SQL数据库语句,如果您还有更好地理解,欢迎沟通 定位:分享 Android&Java知识点,有兴趣可以继续关注

1.9K30

SQL数据库查询语句

一、Select语句: select语句除了可以查看数据库中的表格和视图的信息外,还可以查看SQL Server的系统信息、复制、创建数据表。...其查询功能强大,是SQL语言的灵魂语句,也是SQL中使用频率最高的语句。...基本select语句: 一个基本的select语句可以分解成三个部分:查找什么数据( select )、从哪里查找( from )、查找的条件是什么( where )。...格式: select 表名.列名1,列名2,… from 表名 例2.在xsbook数据库的xs表中查询学生的姓名、专业名、借书数信息。...例11:查询xs表中计算机专业的学生情况 select * from xs where 专业名 like ‘计算机’ 查询相反的情况:则使用以下语句: select * from xs where

4K20
领券