首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    这是我见过最有用的Mysql面试题,面试了无数公司总结的(内附答案)

    18.所有不同类型的索引是什么? 索引有三种类型 1.唯一索引:唯一索引通过确保表中没有两行数据具有相同的键值来帮助维护数据完整性。定义主键时,可以自动应用唯一索引。...在Oracle中使用自动递增关键字 在SQL Server中使用IDENTITY关键字。 29.什么是临时表? 临时表是用于临时存储数据的临时存储结构。 30.如何避免查询中重复记录?...用字段NULL值是没有值的字段。甲NULL值是从零值或包含空格的字段不同。 具有NULL值的字段是在记录创建过程中留为空白的字段。...Union和Union All都将两个表的结果连接在一起,但是这两个查询处理重复表的方式不同。 联合:省略重复的记录,仅返回两个或多个select语句的不同结果集。...如果未与交叉联接一起使用WHERE子句,则交叉联接将产生一个结果集 该结果集是第一个表中的行数乘以第二个表中的行数。 这种结果称为笛卡尔积。

    27.1K20

    数据库模型设计——主键的设计

    在数据库设计时,主要就是对实体和关系的设计,实体表现出来就是表,关系表现出来就是外键。而对于一个表,由两部分组成:主键和属性。主键的简单定义就是表中为每一行数据的唯一标识。...GUID类型在SQL Server中是16个字节,不算短,比4个字节的Int32长多了。...比如员工表把员工号作为主键,那么员工还没有入职,没有员工号的时候,HR需要先维护一些该预入职员工的信息是不可能的。 联合主键 联合主键就是以多个字段来唯一标识每一行数据。...联合主键主要使用在多对多的关系时,中间表就需要使用联合主键。在简单的多对多关系中,我们不需要为中间的关联建立实体,所以中间表可能就只需要两列,分别是两个实体表的主键。...以SQL Server为例,默认情况下,建立主键的列,就会建立聚集索引,但是实际上,我们可以在建立主键时不使用聚集索引。

    1.1K30

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

    比如说访问一行数据,如果是编程语言实现,就需要指定连接数据的方式,打开数据,按某个方式取出数据,最后还要关闭连接,而在SQL Server中,T-SQL仅仅是定义如何去获取所需的数据,而无需考虑实现细节...在SQL Server中,T-SQL需要编译为执行计划才能去执行,在编译过程中,Query Optimizer需要考虑很多元数据,比如说表上的索引、数据分布、估计行数、一些参数配置、硬件环境等,在这其中...,最重要的就是估计行数,SQL Server需要估计行数来估计成本。...比如语句select * from table where a=1 and b=2 这个语句,SQL Server估计的行数会是:     a列的选择率*b列的选择率*表中采样的总行数     因此,当...这里我们举例,假如表中有100万行数据,where a=1的数据有1万条,where b=1的数据有1万条,则A和B的选择性都是1/100=0.01,在Where中A And B联合的估计行数则变为0.01

    2K30

    面试:mysql最全索引与优化详解

    mysql 是我们最常用的数据存储的的程序,它是关系数据库的代表,可以直接服务于我们的常规业务,是我们不能离开的数据存储器,对于关系操作复杂的业务,具有很强的优势。...server 端包括,sql优化器,缓存主件: 一条sql的查询过程: 首先client 向server端发送一条查询sql. server端 先去缓存中进行查询,如果命中缓存,直接返回,否则进入下一个阶段...2. mysql不同存储引擎不同索引的区别 我们在一个数据库里进行创建表的时候可以指定创建的存储引擎 ENGINE=InnoDB; CREATE TABLE QRTZ_CALENDARS ( SCHED_NAME...InnoDb索引 和 MyISAM索引,可以将不同表根据不同需求创建不同的索引表。...值进行排序, 一个表可以有多个辅助索引,辅助索引中索引的逻辑顺序与磁盘上行的物理存储顺序不同; 可以将创建联合索引,但是联合索引遵循最左匹配原则: ?

    73050

    【索引潜规则】-覆盖索引、ICP、MRR详解

    上篇文章我们说了创建索引的方法,有聚簇索引、辅助索引、前缀索引、联合索引等,也说了如何利用索引的排序功能,接着本篇文章主要来说一说索引的几种优化策略,首先我们先说下回表的概念。...一 回表 假设有这么一条SQL,select * from t where age=23,Innodb会通过二级索引找到主键的值20,然后拿着20再回到聚簇索引树搜索找到要找的行数据(data)...下图就展示了该条SQL回表的过程。 ? 通过上图我们可以看到回表的过程需要扫描两棵树,这样增加了磁盘扫描,如何避免回表呢?这就引出了我们下面要将的内容:覆盖索引。...%放在前面时无法利用索引查找,这条SQL只能用到联合索引的age列。...定期清理冗余索引、未使用过得索引以及查看全表扫描的SQL等,具体监控手段请参见之前的文章> 常见的索引失效的场景: 通过索引扫描的行数超过全表的20%-

    1.5K10

    MySQL索引选择底层原理探究-从一个慢查询说起 | 技术创作特训营第一期

    如果我们强制让优化器走uk索引, 结果会如何呢?...10改为limit 20, 会如何呢?...到了14758), mysql引擎此时认为还不如先走联合索引后再排序来的更高效, 因此就自动切到了高效的联合索引....而优化器选择索引的目的,是找到一个最优的执行方案,并用最小的代价去执行sql。扫描行数是影响执行代价的因素之一, 扫描的行数越少,说明访问磁盘数据的次数越少,CPU消耗越少....不过扫描行数并不是唯一断标准,还会结合是否使用了临时表、是否排序等因素进行综合判断.图片mysql优化器选择有如下考虑因素:扫描行数、是否使用临时表、是否排序等等.若排序索引的预估行数row小并且没有filesort

    5.1K65961

    使用polars进行数据分析

    polars VS pandas polars 与 pandas 在许多方面具有截然不同的设计与实现。...具体可以参考 官方文档 实战 下面我们用一个实际的例子来演示如何使用 polars 进行数据分析,并与 pandas 进行对比。...进行数据分析 我们可能想要知道不同的商品类目的访问数据,包括 UV 和 PV。可以分别使用 polars 和 pandas 进行聚合查询。...使用 SQL 进行跨表联合查询 polars 提供 join 方法进行联合查询,不过 join API 比较繁琐,也不是很直观,我们可以使用 SQL 进行跨表联合查询。...然后将 cat_info 注册为一个临时表。 修改之前的 SQL 查询,使用cat_info表进行联合查询,在结果中包括每个类目的名字。 可以查看一下执行计划。 执行查询,用时 12 秒。

    1.6K30

    分库分表后的索引问题

    摘要 最近遇到一个慢sql,在排查过程中发现和分库分表后的索引设置有关系,总结了下问题。...主要是IN里面的值数量不同,会影响扫描行数的不同,所以常常会出现索引选择不一致。...只负责找到对应的表。到表以后,就是和单表一样查询逻辑。 因为分表键不是索引,但是查询语句是必须要带着分表键,那意味着我们的分库分表以后的表索引大部分要建成联合索引了,分表键+索引键。...单索引mysql server要面临着索引选择的问题。 当然并不是绝对的,比如上面我举的那个案例。按照这个思路查看了下其他的分表索引。...果然表上的大部分索引都是非联合索引,还是直接从单表copy过来的索引。这些索引基本上都是无用的,因为都的是userid索引.

    2.7K30

    mysql索引及执行计划

    节点的数据页的号码 2查询如果不满足单列的条件,查询一整行数据 会拿主键值在次 (回表查询) 做聚簇索引的查询 联合索引 select * from ti where name=‘s’ and gender...hints 单独指定/*+ / select @@optimizer mrr 拿name做查询的时候 匹配对应name值对回表之前做个排序走聚簇索引拿整行数据 5.6之后 icp 有联合索引 abc...=b.id 如何选择驱动表 人工干预left join 优化器默认自己选结果集小的 a表先拿a表第每一行判断是不是和b表的行等值 b表有索引 inlj 基于索引的扫描 普通索引 a表先拿a表第每一行扫描...那么order by走的条件就会在server层进行排序 最好的方法是创建一个联合索引 让where和order by 查询和排序条件都覆盖到 using tmp 会使用到临时表 会导致内存压力比较大...统计信息不准确 联合索引应用细节 如何查询联合索引应用那部分索引 explain format=json select 查询的列 from 表名 where a=1 and b=1 and c=

    1.3K31

    PHP数据库编程之MySQL优化策略概述

    全文索引:MyISAM支持 FULLTEXT类型的全文索引(不适用中文,所以要用sphinx全文索引引擎)。InnoDB不支持。 表的具体行数:MyISAM保存有表的总行数,查询count(*)很快。...InnoDB没有保存表的总行数,需要重新计算。 外键:MyISAM不支持。...方式有垂直切分、水平切分和联合切分。 垂直切分:在数据表非常多的时候,把数据库中关系紧密(如同一模块,经常连接查询)的表切分出来分别放到不同的主从server上。...水平切分:在表不多,而表里的数据量非常大的时候,为了加快查询,可以用哈希等算法,将一个数据表分为几个,分别放到不同的服务器上,加快查询。水平切分和数据表分区的区别在于其存储介质上的不同。...联合切分:更多的情况是数据表和表中的数据量都非常大,则要进行联合切分,即同时进行垂直和水平分表,将数据库切分为一个分布式的矩阵来存储。

    1.1K50

    PHP数据库编程之MySQL优化策略概述

    全文索引:MyISAM支持 FULLTEXT类型的全文索引(不适用中文,所以要用sphinx全文索引引擎)。InnoDB不支持。 表的具体行数:MyISAM保存有表的总行数,查询count(*)很快。...InnoDB没有保存表的总行数,需要重新计算。 外键:MyISAM不支持。...方式有垂直切分、水平切分和联合切分。 垂直切分:在数据表非常多的时候,把数据库中关系紧密(如同一模块,经常连接查询)的表切分出来分别放到不同的主从server上。...水平切分:在表不多,而表里的数据量非常大的时候,为了加快查询,可以用哈希等算法,将一个数据表分为几个,分别放到不同的服务器上,加快查询。水平切分和数据表分区的区别在于其存储介质上的不同。...联合切分:更多的情况是数据表和表中的数据量都非常大,则要进行联合切分,即同时进行垂直和水平分表,将数据库切分为一个分布式的矩阵来存储。

    1.3K40

    Tapdata Connector 实用指南:数据入仓场景之数据实时同步到 BigQuery

    本期实用指南以 SQL Server → BigQuery 为例,演示数据入仓场景下,如何将数据实时同步到 BigQuery。...② 创建数据源 SQL Server 的连接 在 Tapdata Cloud 连接管理菜单栏,点击【创建连接】按钮, 在弹出的窗口中选择 SQL Server 数据库,并点击确定。...基于 BigQuery 特性,Tapdata 做出了哪些针对性调整 在开发过程中,Tapdata 发现 BigQuery 存在如下三点不同于传统数据库的特征: 如使用 JDBC 进行数据的写入与更新,则性能较差...在数据增量阶段,先将增量事件写入一张临时表,并按照一定的时间间隔,将临时表与全量的数据表通过一个 SQL 进行批量 Merge,完成更新与删除的同步。...不同于传统 ETL,每一条新产生并进入到平台的数据,会在秒级范围被响应,计算,处理并写入到目标表中。同时提供了基于时间窗的统计分析能力,适用于实时分析场景。

    8.6K10

    PHP中的数据库一、MySQL优化策略综述

    表的具体行数:MyISAM保存有表的总行数,查询count(*)很快。InnoDB没有保存表的总行数,需要重新计算。   外键:MyISAM不支持。...3、进行多条件查询时,对多条件分别建立索引时,执行sql查询时,MySQL只会选择一个最贴近的索引来使用,所以如果需要多条件查询,要建立联合索引,即使会造成数据冗余。...方式有垂直切分、水平切分和联合切分。 垂直切分:在数据表非常多的时候,把数据库中关系紧密(如同一模块,经常连接查询)的表切分出来分别放到不同的主从server上。...水平切分:在表不多,而表里的数据量非常大的时候,为了加快查询,可以用哈希等算法,将一个数据表分为几个,分别放到不同的服务器上,加快查询。水平切分和数据表分区的区别在于其存储介质上的不同。...联合切分:更多的情况是数据表和表中的数据量都非常大,则要进行联合切分,即同时进行垂直和水平分表,将数据库切分为一个分布式的矩阵来存储。

    2.1K80

    Mysql面试题

    在 MyISAM Static 上的所有字段有固定宽度。MyISAM Dynamic 表将具有像TEXT,BLOB等字段,以适应不同长度的数据类型。...实践中如何优化MySQL SQL语句及索引的优化 数据库表结构的优化 系统配置的优化 硬件的优化 详细可以查看 阿里P8架构师谈:MySQL慢查询优化、索引优化、以及表等优化总结 23....SQL注入漏洞产生的原因?如何防止? SQL注入产生的原因:程序开发过程中不注意规范书写sql语句和对特殊字符进行过滤,导致客户端可以通过全局变量POST和GET提交一些sql语句正常执行。...快速访问数据表中的特定信息,提高检索速度 创建唯一性索引,保证数据库表中每一行数据的唯一性。...35.如何通俗地理解三个范式?

    1.2K51

    Mysql的SQL优化指北

    所以我们建议:让主键具有AUTO_INCREMENT,让存储引擎自己为表生成主键。...对于count(主键id)来说,InnoDB引擎会遍历整张表,把每一行的id值都取出来,返回给server层。server层拿到id后,判断是不可能为空的,就按行累加。...对于count(1)来说,InnoDB引擎遍历整张表,但不取值。server层对于返回的每一行,放一个数字“1”进去,判断是不可能为空的,按行累加。...从表t1中读入一行数据 R; 2. 从数据行R中,取出a字段到表t2里去查找; 3. 取出表t2中满足条件的行,跟R组成一行,作为结果集的一部分; 4....这个SQL由于使用了索引,所以在将t1表数据取出来后根据t1表的a字段实际上是对t2表的一个索引的等值查找,所以t1和t2比较的行数是相同的,这样使用被驱动表的索引关联称之为“Index Nested-Loop

    98320

    (4) MySQL中EXPLAIN执行计划分析

    SQL如何使用索引 联接查询的执行顺序 查询扫描的数据函数 二. 执行计划中的内容 SQL执行计划的输出可能为多行,每一行代表对一个数据库对象的操作 1....ID列 ID列中的如果数据为一组数字,表示执行SELECT语句的顺序;如果为NULL,则说明这一行数据是由另外两个SQL语句进行 UNION操作后产生的结果集 ID值相同时,说明SQL执行顺序是按照显示的从上至下执行的...ID值不同时,ID值越大代表优先级越高,则越先被执行 演示 可以看到上面的执行计划返回了3行结果,id列的值可以看作是SQL中所具有的SELECT操作的序号 由于上述SQL中只有一个SELECT,...KEY_LEN列 显示MySQL索引所使用的字节数,在联合索引中如果有3列,假如3列字段总长度为100个字节,Key_len显示的可能会小于100字节,比如30字节,这就说明在查询过程中没有使用到联合索引的所有列...Ref列 表示当前表在利用Key列记录中的索引进行查询时所用到的列或常量 11. rows列 表示MySQL通过索引的统计信息,估算出来的所需读取的行数(关联查询时,显示的是每次嵌套查询时所需要的行数)

    92920

    Mysql的SQL性能优化指北

    所以我们建议:让主键具有AUTO_INCREMENT,让存储引擎自己为表生成主键。...对于count(主键id)来说,InnoDB引擎会遍历整张表,把每一行的id值都取出来,返回给server层。server层拿到id后,判断是不可能为空的,就按行累加。...对于count(1)来说,InnoDB引擎遍历整张表,但不取值。server层对于返回的每一行,放一个数字“1”进去,判断是不可能为空的,按行累加。...从表t1中读入一行数据 R; 2. 从数据行R中,取出a字段到表t2里去查找; 3. 取出表t2中满足条件的行,跟R组成一行,作为结果集的一部分; 4....这个SQL由于使用了索引,所以在将t1表数据取出来后根据t1表的a字段实际上是对t2表的一个索引的等值查找,所以t1和t2比较的行数是相同的,这样使用被驱动表的索引关联称之为“Index Nested-Loop

    88010
    领券