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

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

一个表只能有一个聚集索引 它改变了记录在数据库中的存储方式,因为它通过设置为聚集索引的列对行进行排序。 非聚集索引: 与聚集索引相比,它更慢。...一些广泛使用的SQL字符串函数是 LEN()–返回文本字段中值的长度 LOWER()–将字符数据转换为小写 UPPER()–将字符数据转换为大写 SUBSTRING()–它从文本字段中提取字符 LTRIM...自联接是表与自身联接的联接,特别是当表具有引用其自己的主键的外键时。 73.什么是交叉加入?...如果未与交叉联接一起使用WHERE子句,则交叉联接将产生一个结果集 该结果集是第一个表中的行数乘以第二个表中的行数。 这种结果称为笛卡尔积。...这些函数用于将NULL值替换为另一个值。Oracle开发人员使用NVL函数,MySQL开发人员使用IFNULL函数,而SQL Server开发人员使用ISNULL函数。 假设列中的某些值是NULL。

27.1K20

数据库的总结

,这样的一列或者多列组合叫做表的主键。...如果两列或多列组合起来唯一地标识表中的每一行,则该主键也叫做"组合键";在选择哪列为主键时应该考虑连个原则:最少性和稳定性。...插入数据 113 a.语法:insert [into] 表名> [列名] values 114 b.一次性插入多行数据 115 (1)通过Insert Select...多对一、多对多】、实体关系图) 277 b.如何将E-R图转化为表(多多关系建立表关系是通常拆分为一多关系) 278 6-4:数据规范化 279 a.设计问题(减少数据冗余,维护数据的完整性...【条件我要来源于多表】 559 子查询不仅可存在于结果,也可以是条件 (,=,>=【一行一列】) (in【多行一列】) (exists【多行多列,无条件】) 560 老技术替换新技术

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

    那些年我们写过的T-SQL(上篇)

    赶脚俺弱小的智力已经完全无法记清楚常见的命令了,即使是用的最熟悉的T-SQL(SQL Server)。因此将最常见的T-SQL操作做个简单的总结,包括一些容易忽视的知识点和常见的开发样例。...SELECT字句:指定返回到查询结果表中列的地方,可以包含表达式,推荐给表达式创建一个易懂的别名,比如Year(orderdate) AS OrderYear,尤其是新增一些与列无关的表达式,如current_timestamp...时间日期函数看起来比较简单,但在实际的使用中,由于不同的时间格式,往往会让人非常的困扰,毕竟那么多的API使用起来选择比较多,这儿将最常见的罗列了出来。...关键字 解释与示例 GETDATE(), CURRENT_TIMESTAMP 均是获得当前时间,后者遵循ANSI SQL规范 CAST, CONVERT, PARSE 将输入值转换为目标类型,CAST(...埋下这样一个种子就好 内部联接:最常见和基础的联接方式,包含笛卡尔乘积和筛选两个步骤,相对复杂的情形包括复合联接、不等联接和多联接查询,如下表所示。

    3.2K100

    【21】进大厂必须掌握的面试题-65个SQL面试

    完全联接: 当任何表中都存在匹配项时,完全联接将返回所有记录。因此,它将返回左侧表中的所有行和右侧表中的所有行。 Q16。您所说的非规范化是什么意思?...当将冗余引入表中时,它可以帮助数据库管理员提高整个基础架构的性能。它通过合并数据库查询将冗余数据添加到表中,这些查询将来自不同表的数据组合到一个表中。 Q17。什么是实体和关系?...交叉联接和自然联接有什么区别? 交叉联接产生两个表的叉积或笛卡尔积,而自然联接基于两个表中具有相同名称和数据类型的所有列。 Q28。什么是SQL中的子查询?...多对一关系。 自引用关系。 Q35。插入数据时如何在列中插入NULL值? 可以通过以下方式插入NULL值: 隐式地通过从列列表中省略列。...选择” SQL Server配置属性”,然后选择”安全性”页面。 Q65。什么是STUFF和REPLACE函数? STUFF函数:此函数用于覆盖现有字符或将一个字符串插入另一个字符串。

    6.9K22

    SQL基础查询方法

    SELECT 语句从 SQL Server 中检索出数据,然后以一个或多个结果集的形式将其返回给用户。结果集是对来自 SELECT 语句的数据的表格排列。与 SQL 表相同,结果集由行和列组成。...通过将 OLE DB 数据源链接为链接服务器,或在 OPENROWSET 或 OPENQUERY 函数中引用数据源,可以从 SQL Server 访问 OLE DB 数据源。...FROM 子句还可以包含联接规范。这些联接规范定义了 SQL Server 在从一个表导航到另一个表时使用的特定路径。 FROM 子句还用在 DELETE 和 UPDATE 语句中以定义要修改的表。...PIVOT 通过将表达式某一列中的唯一值转换为输出中的多个列来旋转表值表达式,并在必要时对最终输出中所需的任何其余列值执行聚合。...UNPIVOT 与 PIVOT 执行相反的操作,将表值表达式的列转换为列值。(数据库的兼容级别需要90以上 ) 用 sp_addlinkedserver 定义的链接服务器中的一个或多个表或视图。

    4.3K10

    SQL Server 2012学习笔记 (三) ----- SQL Server SQL语句

    合并操作与联接相似,因为它们都是将两个表合并起来形成另一个表的方法。然而,它们的合并方法有本质上的不同,结果表的形状如下所示。 注:A和B分别代表两个数据源表。 ?   ...4)使用CASE函数进行查询:   联接可分为以下几类:内部联接、外部联接、交叉联接。   CASE函数用于计算条件列表并返回多个可能结果表达式之一。   ...CASE函数具有两种格式: 简单 CASE 函数将某个表达式与一组简单表达式进行比较以确定结果。 CASE 搜索函数计算一组布尔表达式以确定结果。   两种格式都支持可选的 ELSE 参数。...语句 WHILE语句 GOTO语句 WAITFOR语句 RETURN语句 6、批处理语句   批处理是从应用程序发送到SQL Server并得以执行的一条或多条T-SQL语句。...7、规则、默认和完整性约束   规则是对存储的数据表的列或用户定义数据类型中的值的约束,规则与其作用的表或用户定义数据类型是相互独立的,也就是说,对表或用户定义数据类型的任何操作与对其设置的规则不存在影响

    6.5K20

    《深入浅出SQL》问答录

    SQL能控制多位用户同时访问表的行为,能够授予或撤销对整个数据库的访问权,这有时比控制每张表的权限要简单的多。 我发现CREATE DATABASE 命令的字母全是大写,一定要这样吗?...ORDER BY排序 1、升序排序:ASC | 降序排序:DESC 2、SQL排序规则 ? 多列排序: 越靠前的列权重越高,拥有对后面列的一票否决权。...A:外键约束能确保引用完整性(换句话说,如果表中的某行有外键,约束能确保该行通过外键与另一张表中的某一行一一对应)。...右外联接 有外联接与左外联接一样,除了它是用右表与左表比对。 自联接 同一个表可以同时作为外联接的左右表。虽然听起来很奇怪,不过却很好用。 来一题看看; ?...因为当SELECT语句的结果是一个虚表时,若没有别名,SQL就无法取得其中的表。 为什么视图对数据库有好处? 如果创建了视图,就不需要重复创建复杂的联接与子查询。视图隐藏了子查询的复杂性。

    2.9K50

    视图索引

    创建索引视图 视图也称为虚拟表,这是因为由视图返回的结果集其一般格式与由列和行组成的表相似,并且,在 SQL 语句中引用视图的方式也与引用表的方式相同。...查询每次引用视图时,Microsoft® SQL Server™ 2000 会动态地将生成视图结果集所需的逻辑合并到从基表数据生成完整查询结果集所需的逻辑中。...对于标准视图而言,为每个引用视图的查询动态生成结果集的开销很大,特别是对于那些涉及对大量行进行复杂处理(如聚合大量数据或联接许多行)的视图更为可观。...若经常在查询中引用这类视图,可通过在视图上创建唯一聚集索引来提高性能。在视图上创建唯一聚集索引时将执行该视图,并且结果集在数据库中的存储方式与带聚集索引的表的存储方式相同。...视图的聚集索引必须唯一,从而提高了 SQL Server 在索引中查找受任何数据更改影响的行的效率。 与基表上的索引相比,对索引视图的维护可能更复杂。

    1.2K30

    浅谈数据库Join的实现原理

    DB2、SQL Server和Oracle都是使用这三种方式,不过Oracle选择使用nested loop的条件跟SQL Server有点差别,内存管理机制跟SQL Server不一样,因此查看执行计划...,Oracle中nested loops运用非常多,而merge和hash方式相对较少,SQL Server中,merge跟hash方式则是非常普遍。...在 Argument 列中,如果操作执行一对多联接,则 Merge Join 运算符将包含 MERGE:() 谓词;如果操作执行多对多联接,则该运算符将包含 MANY-TO-MANY MERGE:()...SQL Server将切分后的partition文件保存在磁盘上,每次装载一个分区的build input和probe input到内存中,进行一次hash join。...如果多个联接使用相同的联接列,这些操作将分组为一个哈希组。 (2)对于非重复或聚合运算符,使用输入生成哈希表(删除重复项并计算聚合表达式)。生成哈希表时,扫描该表并输出所有项。

    5.4K100

    Hibernate原生SQL查询与结果类型处理

    Hibernate原生SQL查询与结果类型处理在Hibernate中,原生SQL查询是一个强大的工具,它允许开发者直接编写SQL语句来访问数据库。...原生SQL查询示例以下是一个使用Hibernate进行原生SQL查询的示例,它涉及到了多个表的联接和聚合函数的使用:StringBuilder sb = new StringBuilder();sb.append...(省略了其他表的联接和WHERE子句)Query nativeQuery = session.createSQLQuery(sb.toString());List resultList...处理结果类型当处理Hibernate原生SQL查询的结果时,有几种方法可以处理结果类型:手动类型转换:在遍历结果集时,将BigDecimal转换为所需的类型。...nativeQuery.addScalar("billsStatus", StandardBasicTypes.INTEGER);然后,在遍历结果集时,可以直接将结果强制转换为指定的类型。

    22020

    《MSSQL2008技术内幕:T-SQL语言基础》读书笔记(下)

    相信很多人在笔试或面试的时候被问到如何通过SQL实现行转列或列转行的问题,可能很多人当时懵逼了,没关系,下面我们通过例子来理解。   ...换句话说,将透视表中的每个源行潜在地转换成多个行,每行代表源透视表的一个指定的列值。   ...(3)标准SQL进行逆透视转换   Step1.生成副本:CROSS JOIN 交叉联接生成多个副本   Step2.提取元素:通过CASE语句生成qty数据列   Step3.删除不相关的交叉:过滤掉...UPDATE dbo.T1 SET col1 = col2, col2 = col1;   ② 基于联接的UPDATE语句:同样不是SQL标准语法,联接在此与基于联接的DELETE一样是起到过滤作用...(2)批处理:客户端应用程序发送到SQL Server的一组单条或多条T-SQL语句,SQL Server将批处理语句作为单个可执行的单元。 ?

    9K20

    【数据库设计和SQL基础语法】--连接与联接--联接的优化与性能问题

    垂直分割和水平分割: 考虑对表进行垂直分割,将大表拆分为多个表,每个表只包含必要的列。 考虑对表进行水平分割,将大表按行划分为多个子表,减小每个表的数据量。...考虑将大查询拆分为多个小查询,以减少每个查询的复杂性。 通过采取这些优化策略,可以降低联接操作的复杂度,提高查询性能,尤其是在涉及多个表和复杂联接条件的情况下。...以下是与索引相关的性能问题: 缺乏联接条件的索引: 联接操作通常基于联接条件来匹配行。如果涉及的联接列没有相应的索引,数据库引擎将不得不执行全表扫描,导致性能下降。...考虑使用复合索引: 如果涉及多个列的联接条件,考虑使用复合索引,包含这些列。 复合索引可以更有效地加速多列的匹配。 维护索引的选择性: 确保索引具有足够的选择性,能够过滤掉大量的数据。...以下是一些数据库设计的优化策略: 合理拆分表: 将大型表拆分成更小的、彼此关联的表,以减小每个表的数据量。 这可以通过垂直分割(将列拆分为不同的表)或水平分割(将行拆分为不同的表)来实现。

    23811

    MySQL括号字符串计数

    字典表 + 递归查询 总结: 参考: 问题提出: 有一张表 t1 存储用户评论内容,如下所示(只列出相关列): 图片 现在想得出每种评论字数的个数,每个字符包括标点...这是针对类似ID为44132703的这种中括号出现在评论字符串中间的情况,只有这样才能用统一方法进行转多行的操作。...数字辅助表nums是只有一列ID的1、2、3......数列,关联它用笛卡尔积由原表的一行制造出多行。...8-11行中的子查询,得出每条评论中成对中括号的个数(l1列),0表示评论字符串中没有成对的中括号,结果如下: 图片 7-12行中的子查询,结果为使用以“]”为分隔符转的多行: 图片...在本例中,不使用正则表达式的解决方案不但冗长,而且由于用到笛卡尔积由单行转多行,之后再聚合,性能比正则表达式差的多。实际表中有55107行记录,方案1秒出结果,方案2需要执行50多秒。

    1.3K20

    T-SQL基础(一)之简单查询

    在使用NULL值时应注意以下几点: 将NULL与其它值进行比较,不管该值是否为NULL,结果均为Unknown 应使用IS NULL或IS NOT NULL来判断值是否为NULL INSERT未给列指定值则插入...SELECT语句用于指定返回到查询结果集中的列,生成查询结果表。注意,在SELECT子句之前执行的子句无法使用SELECT子句中的列的别名,否则会返回Invalid column name错误。...通常单表查询仅需一句SELECT语句即可,简单且数据库 联接查询 INNER JOIN、LEFT JOIN、RIGHT JOIN、CROSS JOIN 子查询 SQL可以在一个查询语句中编写另外一个查询语句...表表达式 派生表、公用表表达式、视图等 聚合函数 聚合函数对多行数据进行运算后返回标量(聚合),只有SELECT、HAVING、ORDER BY语句中可以使用聚合函数; 开窗函数 开窗函数是对基本查询中的每一行按组...) SQL Server中锁与事务隔离级别 数据库两大神器【索引和锁】 SQL SERVER开窗函数

    4.2K20

    2-SQL语言中的函数

    SQL语言–函数 概念: 将一组逻辑语句封装在方法体内,对外暴露方法名 优点: 隐藏了实现细节,提高了代码的重用性 调用语法: SELECT 函数名(实参列表) 【FROM 表】; 特点: 函数名与函数功能...) WHERE或HAVING后面(标量子查询,列子查询,行子查询) EXISTS 后面(表子查询)按结果集的行列数不同: 标量子查询(结果集只有一行一列) 列子查询(结果集只有一列多行) 行子查询(结果集有一行多列...) 表子查询(结果集一般多行多列) # 子查询 /* 含义: 出现在其他语句中的select语句,称为子查询或内查询 外部出现的查询语句,称为主查或外查询 分类: 按子查询出现的位置: SELECT...(结果集只有一行一列) 列子查询(结果集只有一列多行) 行子查询(结果集有一行多列) 表子查询(结果集一般多行多列) */ # WHERE或HAVING 后面 /* 1....所以不能用标量子查询(多行多列或0行0列都不可以) # 列子查询(多行子查询,因为子查询结果是一列多行) /* 多行操作符: IN/NOT IN 等于/不等于列表中的任意一个 ANY/SOME

    2.8K10

    必知必会——关于SQL中的NOT IN优化

    在开始之前,我们需要记住另外两个SQL细节: WHERE针对行测试条件,并且仅当此条件为TRUE时才让行通过(拒绝FALSE和UNKNOWN)。...与SQL的理解不同,SQL意味着NULL为“也许是煤炭,天然气或其他,或者什么都不是”。 因此,就我的意图而言,NULL不可能是煤炭或木材,因此我希望IN不返回A,并且我希望NOT IN返回A。...我只需要用SQL更好地表达我想要的内容即可。 我可以将NOT IN更改为IN NOT TRUE: ? 这将让IN返回FALSE或UNKNOWN的房屋通过;因此,A和B会如我所愿地通过。...当NOT IN的任何一侧是可为空的列(此处是我们的情况)时, SELECT … WHERE heating NOT IN (SELECT name …) 不能转换为反联接(MySQL 8.0.17的新功能...),因为NOT IN与NULL的行为与关系代数中反联接的定义不匹配。

    4.9K40

    普通程序员必须掌握的SQL优化技巧

    计划执行器需要访问更底层的事务管理器,存储管理器来操作数据,他们各自的分工各有不同,最终通过调用物理层的文件获取到查询结构信息,将最终结果响应给应用层。...通过上面的描述,生成执行计划是执行一条SQL必不可少的步骤,一条SQL性能的好坏,可以通过查看执行计划很直观的看出来,执行计划提供了各种查询类型与级别,方面我们进行查看以及为作为性能分析的依据。...index:该联接类型与ALL相同,除了只有索引树被扫描。这通常比ALL快,因为索引文件通常比数据文件小。ALL:对于每个来自于先前的表的行组合,进行完整的表扫描,说明查询就需要优化了。...在不损失精确性的情况下,长度越短越好 ref 显示使用哪个列或常数与key一起从表中选择行。 rows 显示MySQL认为它执行查询时必须检查的行数。多行之间的数据相乘可以估算要处理的行数。...注意:如果是为了应付面试,最好是能背下来,不能全背下来的情况,也要能说上个123,然后就说,记不得这么多,可以翻阅相关文档来对照着优化SQL。 好了,今天就分享这么多。

    85460

    MySql中应该如何将多行数据转为多列数据

    在 MySQL 中,将多行数据转为多列数据一般可以通过使用 PIVOT(也称为旋转表格)操作来实现。但是,MySQL 并没有提供原生的 PIVOT 操作。...,使用 CASE WHEN 语句根据课程名称动态生成一列新的值; 使用 MAX() 函数筛选出每个分组中的最大值,并命名为对应的课程名称; 将结果按照学生姓名进行聚合返回。...方法二:使用 GROUP_CONCAT 函数 除了第一种方法,也可以使用 GROUP_CONCAT() 函数和 SUBSTRING_INDEX() 函数快速将多行数据转为多列数据。...总结 以上两种实现方法都能够将 MySQL 中的多行数据转为多列数据。...如果使用 PIVOT 正常情况下需要使用第一种方法自己手动构造查询,如果有更高级需求如 CUBE ROLLUP 等只有 Pivot 才能支持,需要考虑换用非开源数据库操作(如Oracle、SQL Server

    1.9K30
    领券