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

SQL简介

= >=,逻辑运算(and or not),between xxx and xxx, where id (not)in(1,2,3,4)查询id在1234中的, is(not) null 可以查询某个字段为空...是对于分组数据的的筛选 where和having在某些情况下可以显示相同的效果但where效率更高,参考sql执行顺序. sql执行顺序 select... from 表名 where 行数据的筛选条件...r,*from tab where rowmun<=10//此处rownum不更换 在tb1结果基础上查询,rownum>6 select * from (tb1) where r>6 查询工资最高的...join 右外连接(右边为主,右找左,左边无,左则为空) right (outer可省) join 全外连接 full (outer可省) join 正常的匹配,不正常的左边为空的显示,右边为空的也显示...is null可以在num上设置默认值0,确保表中num列没有null值,然后这样查询:select id from t where num=0 应尽量避免在 where 子句中使用!

2.7K20

MySQL学习笔记(长期更新)

+1,系统自动赋值 满足唯一约束的字段,可以为空值,但满足主键约束的字段,自动满足非空约束。...HAVING是先连接后筛选,所以WHERE比HAVING更高效 WHERE可以直接使用表中字段作为筛选条件,但不能使用分组中的计算函数作为筛选条件,HAVING必须要与GROUP BY配置使用,可以把分组计算的函数和分组字段作为筛选条件...count(*):统计一共有多少条记录 count(字段):统计有多少个不为空的字段值 count(*)与group by连用统计分组内有多少条数据 计算直接在数据库中执行,比在应用层面完成相同的工作,...张三的爱⼈在⽹上购物,开启了⼀个事务B,也来读取卡内⾦额。如果B读取卡内⾦额的操作,发⽣在A更新 卡内⾦额之后,并且在插⼊销售流⽔之前,那么B读出的⾦额应该是多少呢?...19-日志(上):系统出现问题,如何及时发现? 通用查询日志 通用查询日志记录了所有用户的连接开始时间和截至时间,以及发给MySQL数据库服务器的所有SQL指令。

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

    第37次文章:数据库基本语法

    具体如下: select 查询列表 from 表1 别名 连接类型 join 表2 别名 on 连接条件 where 筛选条件 group by 分组条件 having 分组后筛选条件 order by...在表格属性中我们看到不可以为空的属性有:id、name、phone。所以这三个属性是我们必须插入的值。...第三条语句中,我们使用的是方式二的set方法来,此时在表名后面不用填写需要插入的属性,因为set后面的语法中,已经直接填写了对应的属性。...数据库的命名以及字符集等等属性设置,一般在创建的初始时就需要被设置好。在以后的运维过程中基本也不会有什么变动,可能变化的主要就是数据库的字符集。...比如学生表的专业编号 3、添加约束 (1)添加约束的时机 创建表时 修改表时 (2)约束的添加分类 列级约束:六大约束语法上都支持,但是外键约束没有效果 表级约束:除了非空、默认,其他的都支持 4、案例

    1.3K10

    企业面试题|最常问的MySQL面试题集合(一)

    服务器层不管理事务,由下层的引擎实现,所以同一个事务中,使用多种引擎是不靠谱的。 需要注意,在非事务表上执行事务操作,MySQL不会发出提醒,也不会报错。...varchar可直接创建索引,text创建索引要指定前多少个字符。varchar查询速度快于text,在都创建索引的情况下,text的索引几乎不起作用。 查询text需要创建临时表。...3、列值为空(NULL)时是可以使用索引的,但MySQL难以优化引用了可空列的查询,它会使索引、索引统计和值更加复杂。可空列需要更多的储存空间,还需要在MySQL内部进行特殊处理。...聚簇索引是一种数据存储方式,它实际上是在同一个结构中保存了B+树索引和数据行,InnoDB表是按照聚簇索引组织的(类似于Oracle的索引组织表)。...当然,如果计划对列进行索引,就要尽量避免把它设置为可空,MySQL难以优化引用了可空列的查询,它会使索引、索引统计和值更加复杂。

    69932

    mysql面试题目及答案_docker 面试题

    持久性(durability):一旦事务提交,则其所做的修改就会永久保存到数据库中。此时即使系统崩溃,修改的数据也不会丢失。 2.事务的隔离级别,mysql默认的隔离级别是什么?...第三范式:在满足第二范式的基础上,在实体中不存在其他实体中的非主键属性,传递函数依赖于主键属性,确保数据表中的每一列数据都和主键直接相关,而不能间接相关(表中字段[非主键]不存在对主键的传递依赖) 10...在进行表链接后会筛选掉重复的记录,Union All不会去除重复记录; 对排序的处理:Union将会按照字段的顺序进行排序;UNION ALL只是简单的将两个结果合并后就返回; 从效率上说,UNION...=操作,但,>=,BETWEEN,IN是可以用到索引的;索引要建立在经常进行select操作的字段上;索引要建立在值比较唯一的字段上;对于那些定义为text、image和bit数据类型的列不应该增加索引...,并转为一个常量时,使用这些访问类型;如果将主键置于where列表中,MySQL就能将该查询转化为一个常量;possible_keys:显示可能应用在这张表中的索引;如果为空,没有可能的索引;可以为相关的域从

    1.1K20

    盘点数据库中的一些坑(一)

    前置条件 在讲解具体的踩坑点之前,我们构建一个简单的表: CREATE TABLE `admin` ( `id` int NOT NULL AUTO_INCREMENT COMMENT '主键,自增...= null,is not null这两条语句经常被弄混,他们在表面的含义似乎都是“「不为空」”,但是实际上他们含义是完全不同的,强烈建议在进行判断数据库字段内容是否为null的时候用not null来表示不为空...,就直接粘贴过来了: ❝ null 你可以理解为一片空。...不利于代码的可读性和可维护性,特别是强类型语言,查询 INT 值,结果得到一个 NULL,程序可能会崩溃...如果要兼容这些情况程序往往需要多做很多操作来兜底(异常情况多数发生在Mapper的实体属性映射上...,就有可能存在问题,这个坑比较好理解,所以这里直接总结join的一些特性: 两表直接笛卡尔积的结果数量是两表的数据量相乘 带where条件id相等的笛卡尔积和inner join结果相同,但是inner

    38620

    最常问的MySQL面试题集合

    服务器层不管理事务,由下层的引擎实现,所以同一个事务中,使用多种引擎是不靠谱的。 需要注意,在非事务表上执行事务操作,MySQL不会发出提醒,也不会报错。...3、列值为空(NULL)时是可以使用索引的,但MySQL难以优化引用了可空列的查询,它会使索引、索引统计和值更加复杂。可空列需要更多的储存空间,还需要在MySQL内部进行特殊处理。...当然,如果计划对列进行索引,就要尽量避免把它设置为可空,MySQL难以优化引用了可空列的查询,它会使索引、索引统计和值更加复杂。...,不要直接打开慢查询日志进行分析,这样比较浪费时间和精力,可以使用pt-query-digest工具进行分析 使用show profile set profiling=1;开启,服务器上所有执行语句会记录执行时间...解决办法:避免使用SELECT * 重复查询相同的数据。解决办法:可以缓存数据,下次直接读取缓存 是否在扫描额外的记录。

    90530

    定了!MySQL基础这样学

    FROM 表名 [WHERE]; -- SELECT 选择要查询的列 -- FROM 提供数据源 (表、视图或其他的数据源) -- 可以写*表示查询所有列,但是在实际开发中基本上不会使用,性能低,实际开发中是将所有字段列出来...查询语句的字句的执行顺序 FROM 子句: 从哪张表中去查询数据 => WHERE 子句 : 筛选需要哪些行的数据 => SELECT 子句: 筛选要显示的列。...SQL语句中有一个语法规则,分组函数不可以直接使用在where字句当中。原因是因为:group by是在where执行之后才会执行。...三张表,关系表两外键 14.3、第三范式     建立在第二范式的基础上,所有非主键字段直接依赖主键,不能产生传递依赖。     典型的例子就是一对多,遇到一对多问题的时候背口诀:一对多?...三张表,关系表两外键 14.3、第三范式     建立在第二范式的基础上,所有非主键字段直接依赖主键,不能产生传递依赖。     典型的例子就是一对多,遇到一对多问题的时候背口诀:一对多?

    2.2K20

    MySQL_库和表的使用(部分未完

    一般选择int类型字段作为主键(比如ID之类) 新建表时创建主键 方法一:在设置字段的时候设置上主键 方法二:在最后设置主键 两种方式都会用到 主键本身就不能为空,因此可以省略not null 取消主键...注意去重只是去掉所有字段都重复的数据,所以结果中,就算有一个字段存在重复的数据,但是其他字段不重复,该数据也不会被去掉 条件查询(where)【重要】 基本用法就是在表名后加where,后面是查询条件...NOT NULL查询: where查询条件不一定必须存在于select要查询的字段中: 使用where时设置条件的字段,可以与select查询要获取的结果集字段无关,而是可以根据原有表中任意字段进行筛选...,参考英语的升序 按求和结果排序 排序的时候可以使用别名,说明排序只是对于查询后的结果表进行排序,而不同于where(在查询时按条件筛选) where + order by 查询语文成绩大于70分的学生的...id、姓名、数学成绩 并将查询结果按照语文成绩,降序排列 where查询条件不一定必须存在于select要查询的字段中,而是可以根据原有表中任意字段进行筛选 排序也不一定按照select查询结果的字段进行排序

    12210

    Mysql基础

    主索引是聚簇索引,在索引中保存了数据,从而避免直接读取磁盘,因此对查询性能有很大的提升。...每当与表相关联的事件发生时,即会执行或触发SQL触发器,例如插入,更新或删除。 QL触发器是一种特殊类型的存储过程。 这是特别的,因为它不像直接像存储过程那样调用。...游标:是对查询出来的结果集作为一个单元来有效的处理) 7 视图优缺点(优点:选择性的读取数据库、通过简单查询的得到一些原本需要复杂查询才能得到的结果、维护数据的独立性,试图可从多个表检索数据、对于相同的数据可产生不同的视图...尽量不做全表查询、减少表关联、优化查询字段等等) 9 数据库三范式(1NF:确保每一列的原子性 2NF:非键字段必须依赖于键字段 3NF:在1NF基础上,除了主键以外的其它列都不传递依赖于主键列,或者说...: 任何非主属性不依赖于其它非主属性 (在2NF基础上消除传递依赖)) 11 SQL语言共分为四大类(数据查询语言DQL:select /from/where,数据操纵语言DML:insert/update

    1.8K00

    Swift学习总结

    switch支持值绑定,在case语句中声明变量或常量,其值绑定为状态码的值。switch绑定值可以配合where语句使用,能额外检查一些条件,这个特性可以创建动态筛选条件。...10、for-in循环支持where子句,如 for i in 1…100 where I%3==0 { } Where子句是用来替代for-in中的if条件判断,使代码看起来更优雅,是可替代的。...隐式展开可空类型与普通可空类型重要区别就是不需要展开,使用上不需要if条件语句了。如果这种隐式展开可空类型没有值的话,访问其值会直接导致运行时错误。...建议如果某个实例可能为nil,就不要使用隐式展开可空类型。 23、实例后面跟问号?——可空链式调用,与可空实例绑定类似,两者重要区别是,可空链式调用允许把多个查询串联为一个可空实例的值。...不过也有个例外,可以在try后面跟随感叹号。与强制展开可空实例一样,一旦出现错误程序就会崩溃。该用法谨慎使用,少用。 还有第三种情况,可以用try?

    3K20

    MySQL 的索引查询以及优化技巧

    : MyISAM:MySQL的旧版本的默认引擎,它不支持事务和行级锁,允许开发人员手动控制表锁;支持全文索引;在崩溃后不能安全恢复;支持压缩表,这些表不能修改,但占用更少的空间,并且可以提高查询性能。...尽量使用简单的类型,如能用int就不用char,因为后者的排序涉及到字符集的选择,比使用int复杂。可空列使用更多的存储空间,如果在可空列上创建索引,MySQL需要额外的字节做记录。...创建表时,默认都是可空,容易被开发者忽视,最好是手动改为不可空,如果要存储的数据确实不会有空值的话。...需要注意的是:虽然varchar(5)和varchar(200)在存储“hello”这个字符串时使用相同的存储空间,但并不意味着将varchar的长度设置太大不会影响性能,实际上,MySQL的某些内部计算...查询优化 查询慢的原因 是否向数据库请求了多余的行 比如应用程序只需要10条数据,但是却向数据库请求了所有的数据,在显示在UI上之前抛弃了大部分数据。

    1.2K00

    10 分钟掌握 MySQL 的索引查询优化技巧

    支持热备份 其它常见存储引擎特点概述: MyISAM:老版本MySQL的默认引擎,不支持事务和行级锁,开发者可以手动控制表锁;支持全文索引;崩溃后无法安全恢复;支持压缩表,压缩表数据不可修改,但占用空间较少...尽量使用简单的类型,如能用int就不用char,因为后者的排序涉及到字符集的选择,比使用int复杂。可空列使用更多的存储空间,如果在可空列上创建索引,MySQL需要额外的字节做记录。...创建表时,默认都是可空,容易被开发者忽视,最好是手动改为不可空,如果要存储的数据确实不会有空值的话。...需要注意的是:虽然varchar(5)和varchar(200)在存储“hello”这个字符串时使用相同的存储空间,但并不意味着将varchar的长度设置太大不会影响性能,实际上,MySQL的某些内部计算...查询优化 查询慢的原因 是否向数据库请求了多余的行 比如应用程序只需要10条数据,但是却向数据库请求了所有的数据,在显示在UI上之前抛弃了大部分数据。

    97820

    Mysql基础

    主索引是聚簇索引,在索引中保存了数据,从而避免直接读取磁盘,因此对查询性能有很大的提升。...每当与表相关联的事件发生时,即会执行或触发SQL触发器,例如插入,更新或删除。 QL触发器是一种特殊类型的存储过程。 这是特别的,因为它不像直接像存储过程那样调用。...游标:是对查询出来的结果集作为一个单元来有效的处理) 7 视图优缺点(优点:选择性的读取数据库、通过简单查询的得到一些原本需要复杂查询才能得到的结果、维护数据的独立性,试图可从多个表检索数据、对于相同的数据可产生不同的视图...尽量不做全表查询、减少表关联、优化查询字段等等) 9 数据库三范式(1NF:确保每一列的原子性 2NF:非键字段必须依赖于键字段 3NF:在1NF基础上,除了主键以外的其它列都不传递依赖于主键列,或者说...: 任何非主属性不依赖于其它非主属性 (在2NF基础上消除传递依赖)) 11 SQL语言共分为四大类(数据查询语言DQL:select /from/where,数据操纵语言DML:insert/update

    1.5K00

    数据库基础与SQL基础知识整理

    对应起来 五:视图(方便查询) 1.简介: 视图是一张虚拟表,它表示一张表的部分数据或多张表的综合数据,其结构和数据是建立在对表的查询基础上,以表为基础建立视图,建立后便会存在数据库里面 视图在操作上和数据表没有什么区别...////上放的表格 说明 sp_databases 列出服务器上的所有数据库。...【在SQL内部把触发器看做是存储过程但是不能传递参数】 一般的存储过程通过存储过程名称被直接调用,而触发器主要是通过事件进行触发而被执行。...在执行delete或update操作时,被删除的行从激活触发器的表中被移动(move)到deleted 表,这两个表不会有共同的行。...4.种类: After触发器: 在语句执行完毕之后触发 按语句触发,而不是所影响的行数,无论所影响为多少行,只触发一次。 只能建立在常规表上,不能建立在视图和临时表上。

    1.3K10

    数据库基础与SQL基础知识看这篇就够了!

    对应起来 五:视图(方便查询) 1.简介: 视图是一张虚拟表,它表示一张表的部分数据或多张表的综合数据,其结构和数据是建立在对表的查询基础上,以表为基础建立视图,建立后便会存在数据库里面 视图在操作上和数据表没有什么区别...上放的表格 说明 sp_databases 列出服务器上的所有数据库。...【在SQL内部把触发器看做是存储过程但是不能传递参数】 一般的存储过程通过存储过程名称被直接调用,而触发器主要是通过事件进行触发而被执行。...在执行delete或update操作时,被删除的行从激活触发器的表中被移动(move)到deleted 表,这两个表不会有共同的行。...4.种类: After触发器: 在语句执行完毕之后触发 按语句触发,而不是所影响的行数,无论所影响为多少行,只触发一次。 只能建立在常规表上,不能建立在视图和临时表上。

    1K20

    异常处理第一讲(SEH),筛选器异常,以及__asm的扩展,寄存器注入简介

    异常处理第一讲(SEH),筛选器异常,以及__asm的扩展 一丶__Asm的扩展知识 ①丶使用关键字,解决局部变量申请问题 昨天已经介绍了__asm的基本用法,现在对其做个扩展(上一篇是32为汇编第七讲...例如MSDN上查询到的 ?...C00005这种异常,空指针异常 作用:   相信大家可能都遇到过程序崩溃的情况,或者我们有时候使用QQ 通讯工具的时候也会崩溃 :) 那么QQ处理的就是弹出一个框,让你发送错误报告什么的,为什么,因为...在进程范围内,筛选器异常处理回调函数是惟一的,设置了一个新的回调函数后,原来的就失效了。...上下一个自己MSDN查询把 :) 3.筛选器异常的反调试功能 为什么这样说,上面我们用异常输出了一个信息框,但是现在我们在里面藏着我们的代码,如果我们调试, 那么异常就会被OD接受,也就是说我们的异常函数不会到的

    1.7K100

    一条 sql 的执行过程详解

    前后两条查询SQL必须完全一致。 2、查询语句中含有一些不确定的值时,则不会缓存。...,但其实会用到,虽然索引必须符合最左原则才能使用,但是本质上,优化器会自动将这条sql优化为:where A=x and B=x and C=X,这种优化会为了底层能够匹配到索引,同时在这个阶段是自动按照执行计划进行预处理...读操作 查询的过程和更新比较相似,但是有些不同,主要是来源于他们在查找筛选时的不同,更新因为在查找后会进行更新操作,所以查询这一行为至始至终都在缓冲池中(使用到索引且缓冲池中包含数据对应的数据页)。...= 'a' 在5.6 之前,是不分 Table Filter 与 Index Filter 的,这两个条件都直接分配到 Server 层进行筛选。...筛选过程是先根据 Index Key 的条件先在引擎层进行初步筛选,然后得到对应的主键值进行回表查询得到初筛的行记录,传入 Server 层进行后续的筛选,在 Server 层的筛选因为没有用到索引所以会进行全表扫描

    69530

    10张图,搞懂索引为什么会失效?

    但这样做的前提是这个映射关系需要保存到连续的空间,如数组。...数据很多时,一个目录项肯定很多,毕竟一个页的大小为16k,我们可以对数据建立多个目录项目,在目录项的基础上再建目录项,如下图所示 ?...图片来自《MySQL实战45讲》 在5.6引入了索引下推优化,可以在遍历索引的过程中,对索引中包含的字段做判断,直接过滤掉不满足条件的数据,减少回表次数,如下图 ?...MySQL中,有两种方式生成有序结果集: 通过有序索引顺序扫描直接返回有序数据 Filesort排序,对返回的数据进行排序 因为索引的结构是B+树,索引中的数据是按照一定顺序进行排列的,所以在排序查询中如果能利用索引...当别人问我索引在什么条件下会失效时,我能背出一大堆规则 不要在索引列上进行运算或使用函数 前导模糊查询不会使用索引,例如 like %李 负向条件索引不会使用索引,建议用in。负向条件有:!

    1.2K40

    一条 sql 的执行过程详解

    5、在存储的函数,触发器或事件的主体内执行的查询。 6、如果表更改,则使用该表的所有高速缓存查询都变为无效并从缓存中删除,这包括使用 MERGE 映射到已更改表的表的查询。...,但其实会用到,虽然索引必须符合最左原则才能使用,但是本质上,优化器会自动将这条sql优化为:where A=x and B=x and C=X,这种优化会为了底层能够匹配到索引,同时在这个阶段是自动按照执行计划进行预处理...读操作 查询的过程和更新比较相似,但是有些不同,主要是来源于他们在查找筛选时的不同,更新因为在查找后会进行更新操作,所以查询这一行为至始至终都在缓冲池中(使用到索引且缓冲池中包含数据对应的数据页)。...= 'a' 在5.6 之前,是不分 Table Filter 与 Index Filter 的,这两个条件都直接分配到 Server 层进行筛选。...筛选过程是先根据 Index Key 的条件先在引擎层进行初步筛选,然后得到对应的主键值进行回表查询得到初筛的行记录,传入 Server 层进行后续的筛选,在 Server 层的筛选因为没有用到索引所以会进行全表扫描

    1.3K20
    领券