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

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

索引为每个值创建一个条目,因此检索数据会更快。 19.解释不同类型的索引。 索引分为三种: 唯一索引: 如果列是唯一索引的,则此索引不允许字段具有重复的值。如果定义了主键,则可以自动应用唯一索引。...第一范式(1NF) –行内没有重复的组 第二范式(2NF) –每个非键(支持)列的值都取决于整个主键。 第三范式(3NF) –仅取决于主键,而没有其他非键(支持)列值。 Q23。...交叉联接产生两个表的叉积或笛卡尔积,而自然联接基于两个表中具有相同名称和数据类型的所有列。 Q28。什么是SQL中的子查询? 子查询是另一个查询中的查询,其中定义了查询以从数据库中检索数据或信息。...它不被视为独立查询,因为它引用另一个表并引用一个表中的列。 不相关的子查询:此查询是一个独立的查询,在主查询中替换了子查询的输出。 Q30。列出获取表中记录计数的方法?...聚合函数用于评估数学计算并返回单个值。这些计算是从表中的列进行的。例如-max(),count()是针对数字计算的。 标量函数根据输入值返回单个值。

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

    sql基础之多表查询?嵌套查询?

    SQL不仅在传统的数据库如Oracle, SQL Server, MySQL中广泛使用,在现代的BigData和NoSQL系统中也扮演着重要角色。...主键 主键是表中的一列(有时是一组列),是每行的唯一标识符。数据库通常有一个名为 id 的列(customerID、emailID、EmployeeID)作为每个表的主键。...外键 外键是表中的列,指定到另一个表中主键的链接。例如,在上图中,albums 表中的artist_id 列是artists 表中id 的外键。...如果可能,内联接将组合公共维度(前 N 列)上的列,并且仅包含公共 N 列中共享相同值的列的数据。在上面的示例中,User_ID 将是用于内连接的公共维度。...右连接尽可能组合公共维度上的列(前 N 列),返回第二个/右表中的所有行以及第一个/左表中的匹配行。 举一个例子 多表查询是SQL查询中的一个重要环节,用于从两个或更多表中查询相关数据。

    60410

    从SQL注入到脚本

    下表显示了不同id值的情况: 所有这些方法都基于数据库的一般行为,发现和利用SQL注入取决于许多不同的因素,尽管这些方法本身并不是百分之百可靠的。...使用UNION开发SQL注入 使用UNION开发SQL注入的步骤如下: 查找要执行并集的列数 查找页面中回显的列 从数据库元表中检索信息 从其他表/数据库检索信息 为了通过SQL注入执行请求,需要找到查询第一部分返回的列数...您将尝试以下步骤: SELECT id,name,price FROM articles where id=1 UNION SELECT 1, 注入1 UNION SELECT 1将返回错误,因为查询的两个子部分中的列数不同...其他数据库的方法不同,值为1、2、3…,应更改为null、null、null…对于在UNION关键字的两侧需要相同类型值的数据库。...1 ORDER BY 4注入ORDER BY 4将返回错误,因为查询的第一部分中的列数小于4; 基于这种二分法搜索,我们知道列数为3,现在可以使用此信息构建最终查询:SELECT id,name,price

    2.1K10

    元数据和微调为何是将NLQ扩展到SQL的关键

    对于给定的查询,需要根据员工ID进行连接,并且项目持续时间必须超过六个月。如所示,LLM生成的查询计算持续时间的计算方式不正确。另一个LLM出现幻觉的例子是LLM无法确定正确的列来构成表中的列名。...在下表中,我们为每个数据集类别提供了一个示例定义。这些定义应该根据底层模式、业务查询等进行调整。...一致性定义为模型对给定的NLQ产生相同结果的能力。需要注意的是,SQL查询可能不同,但结果将保持不变。测试SQL查询是否保持不变将很有趣。最后,另一个需要评估的指标是生成的SQL查询的效率。...解决这个问题的不同方法: 识别业务用户最常用的表,并确保为这些表手动创建元数据。 自动创建元数据。 使用GenAI系统检查每个表中随机抽取的几行来创建所有表的元数据草稿。...让专家检查和编辑元数据,以确保它们为表中的列提供正确的描述。 本文总结了在实现生产级企业级NLQ到SQL系统中的五大挑战。使用这些系统可以持续地达到超过90%的准确率。

    7710

    查询优化器基础知识—SQL语句处理过程

    为此,数据库使用散列算法为每个SQL语句生成散列值。 语句哈希值是V$SQL.SQL_ID 中显示的 SQL ID。...此哈希值在 Oracle 数据库版本中是确定性的,因此单个实例或不同实例中的相同语句具有相同的 SQL ID。...SQL语句的哈希值与以下值不同: 语句的内存地址 Oracle 数据库使用 SQL ID 在查找表中执行键值读取。这样,数据库就可以获得语句的可能内存地址。...该语句的执行计划的哈希值 SQL 语句可以在共享池中具有多个计划。通常,每个计划都有不同的哈希值。如果相同的 SQL ID 具有多个计划哈希值,则数据库就会知道此 SQL ID 存在多个计划。...步骤1 执行另一个散列连接,接受来自步骤2和6的行源,将步骤6源中的每一行连接到步骤2中的相应行,并将结果返回给客户端。

    4K30

    SQL索引一步到位

    返回某范围内的数据 应 不应 小数目的不同值 应 不应 大数目的不同值 不应 应 频繁更新的列 不应 应 频繁修改索引列 不应 应 一个或极少不同值 不应 不应 建立索引的原则: 1) 定义主键的数据列一定要建立索引...如果建立的是复合索引,索引的字段顺序要和这些关键字后面的字段顺序一致,否则索引不会被使用。 7) 对于那些查询中很少涉及的列,重复值比较多的列不要建立索引。...当你使用一个dmv时,你需要紧记SQL Server收集这些信息有多长时间了,以确定这些从dmv返回的数据到底有多少可用性。...另一方面,SQL Server只能维持一定量的信息,有些信息在进行SQL Server性能管理活动的时候可能丢失,所以如果SQL Server已经运行了相当长的一段时间,一些统计数据就有可能已被覆盖。...在上面的步骤中,对ProductID = 112的每个主键记录(这里是400),SQL Server引擎要搜索400次聚集索引树以检索查询中指定的其它列(SalesDate,SalesPersonID)

    1.6K20

    SqlAlchemy 2.0 中文文档(二十四)

    以下是一个使用 SQL Server TIMESTAMP 列作为主键的模型;在 SQL Server 上,这种数据类型会自动生成新值,因此在表元数据中通过为 Column.server_default...通常,包含与上一行不同的 NULL 值组合的每个列集必须省略 INSERT 语句中的一系列不同列,这意味着必须将其作为单独的语句发出。...include_collections – 表示是否应该包含多值集合在操作中。将其设置为False是一种仅检测基于本地列的属性(即标量列或多对一外键)的方法,这些属性在刷新时会导致此实例的更新。...通常,每个包含与上一行不同组合的 NULL 值的列集必须从呈现的 INSERT 语句中省略一个不同的系列列,这意味着它必须作为一个单独的语句发出。...将其设置为False是一种检测仅基于本地列的属性(即标量列或多对一外键)的方法,这些属性在刷新此实例时将导致 UPDATE。

    41310

    SqlAlchemy 2.0 中文文档(二)

    某些类别的函数返回整行而不是列值,在需要引用特定列的情况下;这些函数被称为表值函数。...在 SQL 中,窗口函数允许指定应用函数的行,一个“分区”值,考虑窗口在不同子行集上的情况,以及一个“order by”表达式,重要的是指示应用到聚合函数的行的顺序。...某些类别的函数返回整行而不是列值,需要引用特定列;这些函数被称为表值函数。 当执行语句并获取行时,函数的 SQL 返回类型也可能很重要,对于那些 SQLAlchemy 需要应用结果集处理的情况。...在 SQL 中,窗口函数允许指定应用函数的行,一个“分区”值,该值考虑了对不同行子集的窗口,以及一个“order by”表达式,这个表达式重要地指示应用到聚合函数的行的顺序。...这种形式的函数在 PostgreSQL 数据库中很突出,然而一些形式的表值函数也受 SQLite、Oracle 和 SQL Server 支持。

    45410

    如何在Ubuntu 16.04上使用MySQL全文搜索提高搜索效果

    (id, title, content, author) VALUES 指定应存储每个条目的数据值的列。 最后三行是我们添加到表中的三行数据。...现在您可以在SQL查询中使用FTS函数来查找与搜索输入相关的行,您可以使这些结果更具相关性。 第三步 - 完善FTS结果 有两种技术可以帮助使全文搜索结果更具相关性。...您可以使用这些分数首先返回最相关的结果,或仅返回高于特定相关范围的结果。相关性得分因数据集而异,因此选择截止点需要手动调整。...您可以更改截止值以继续微调结果。例如,如果您使用0.1 而不是0截止,则仅返回第2行。 使用IN BOOLEAN 在第二步中,您在指定查询字词时使用了默认的IN NATURAL LANGUAGE模式。...在搜索具有不同词汇表的非常大的文档时,通过搜索词之间的距离限制搜索结果会很有帮助。查询术语之间的差距越小,结果就越准确,尽管微调距离将取决于您正在使用的文档集。

    2.4K40

    SqlAlchemy 2.0 中文文档(七十五)

    警告存在冲突值的功能仍然对于两种情况都是可行的,但是会增加相当大的性能开销,因为在合并过程中每个列值都必须进行比较。...对象与三个新的Order对象合并,每个对象都引用一个不同的Address对象,但每个对象都具有相同的主键。...警告存在冲突值的功能仍然对于两种情况都是可行的,但会增加相当大的性能开销,因为在合并过程中每个列值都必须进行比较。...对象与三个新的Order对象合并,每个对象都引用一个不同的Address对象,但每个对象都具有相同的主键。...警告存在冲突值的功能仍然适用于两种情况,但会增加相当大的性能开销,因为在合并过程中必须比较每个列值。

    33010

    SQL Server 使用全文索引进行页面搜索

    全文索引是一种特殊类型的基于标记的功能性索引,它是由 SQL Server 全文引擎生成和维护的。生成全文索引的过程不同于生成其他类型的索引。...在 SQL Server 2008 中,全文索引大小仅受运行 SQL Server 实例的计算机的可用内存资源限制。...创建全文索引的表必须要有一个唯一的非空索引,并且这个唯一的非空的索引只能是一个字段,不能是组合字段。 每个表只允许有一个全文索引。若要对某个表创建全文索引,该表必须具有一个唯一且非 Null 的列。...同义词库文件 这些文件包含搜索项的同义词。 非索引字表对象 非索引字表对象包含对搜索无用的常见词列表。 SQL Server 查询处理器 查询处理器编译并执行 SQL 查询。...在 SQL Server 2008 和更高版本中,SQL Server 的全文引擎在 SQL Server 查询处理器内部运行。 索引编写器(索引器) 索引编写器生成用于存储索引标记的结构。

    3.3K70

    SQL基础【二十、索引】(超细致版本,前理论,后实践,应对sql面试绰绰有余)

    如果建立的是复合索引,索引的字段顺序要和这些关键字后面的字段顺序一致,否则索引不会被使用。 7) 对于那些查询中很少涉及的列,重复值比较多的列不要建立索引。...当你使用一个dmv时,你需要紧记SQL Server收集这些信息有多长时间了,以确定这些从dmv返回的数据到底有多少可用性。...另一方面,SQL Server只能维持一定量的信息,有些信息在进行SQL Server性能管理活动的时候可能丢失,所以如果SQL Server已经运行了相当长的一段时间,一些统计数据就有可能已被覆盖。...在上面的步骤中,对ProductID = 112的每个主键记录(这里是400),SQL Server引擎要搜索400次聚集索引树以检索查询中指定的其它列(SalesDate,SalesPersonID)...它将date作为前导列,使每个SQL都可以利用索引,并且在第一和第三个SQL中形成了索引覆盖,因而性能达到了最优。

    1.1K20

    如何编写SQL查询

    SQL 具有不同的语言元素,在高级别上可以分为 查询和数据操作。SQL 查询使用 SELECT 语句,而用于数据操作的 SQL 使用 INSERT、UPDATE、DELETE 和 MERGE 语句。...,这些组件按照它们在查询中出现的顺序执行。...GROUP BY: 将具有指定列中公共值的行的聚合(或分组)到一行中。GROUP BY 子句将具有公共值的行的聚合到一行中,因此行数将与唯一值的数量一样多。...对于未在 GROUP BY 中指定的列的值,SELECT 子句中的聚合函数需要按组聚合这些值。 HAVING: 过滤由 GROUP BY 子句生成的行。...如果省略 ORDER BY,则 SQL 查询返回的行顺序是未定义的。 OFFSET: 指定在返回数据之前在结果集中跳过的行数。 FETCH: 指定从结果返回的行数。

    13010

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

    数据库查询可以是选择查询或动作查询。 24.什么是子查询? 子查询是另一个查询中的SQL查询。它是Select语句的子集, 其返回值用于过滤主查询的条件。 25.子查询的类型是什么?...在SQL Server中,数据库表中的每一列都有一个名称和一种数据类型。 在创建SQL表时,我们需要决定在表的每一列中存储哪种数据类型。 57.可以在BOOLEAN数据字段中存储哪些可能的值?...SQL中的聚合函数是什么? SQL聚合函数返回单个值,该值是根据列中的值计算得出的。...该查询将返回“ SQL Server中的查询”。...这三个功能以相同的方式工作。这些函数用于将NULL值替换为另一个值。Oracle开发人员使用NVL函数,MySQL开发人员使用IFNULL函数,而SQL Server开发人员使用ISNULL函数。

    27.1K20

    SqlAlchemy 2.0 中文文档(七十九)

    (除了 Sybase),使用绑定参数进行实际值,这允许更好的查询优化器性能,因为具有不同 LIMIT/OFFSET 的多个语句的文本字符串现在是相同的。...确保所有后端在 result.inserted_primary_key 中一致地返回 None - 一些后端可能之前返回过一个值。在主键列上使用 server_default 是极不寻常的。...确保所有后端一致地对这些值在 result.inserted_primary_key 中返回 None - 一些后端以前可能返回了一个值。在主键列上使用 server_default 是极不常见的。...当在 Integer PK 列上存在 server_default 时,已确立一致性。 SQLA 不会预取这些值,它们也不会在 cursor.lastrowid(DBAPI)中返回。...确保所有后端一致地在 result.inserted_primary_key 中为这些值返回 None-一些后端以前可能返回了一个值。 在主键列上使用 server_default 是极不寻常的。

    10210

    SQL Server 使用全文索引进行页面搜索

    全文索引是一种特殊类型的基于标记的功能性索引,它是由 SQL Server 全文引擎生成和维护的。生成全文索引的过程不同于生成其他类型的索引。...在 SQL Server 2008 中,全文索引大小仅受运行 SQL Server 实例的计算机的可用内存资源限制。...创建全文索引的表必须要有一个唯一的非空索引,并且这个唯一的非空的索引只能是一个字段,不能是组合字段。 每个表只允许有一个全文索引。若要对某个表创建全文索引,该表必须具有一个唯一且非 Null 的列。...同义词库文件 这些文件包含搜索项的同义词。 非索引字表对象 非索引字表对象包含对搜索无用的常见词列表。 SQL Server 查询处理器 查询处理器编译并执行 SQL 查询。...在 SQL Server 2008 和更高版本中,SQL Server 的全文引擎在 SQL Server 查询处理器内部运行。 索引编写器(索引器) 索引编写器生成用于存储索引标记的结构。

    2.9K50

    mysql和sqlserver区别_一定和必须的区别

    : select * from table1 limit 5或则是 limit 0,5; 注意,在MySQL中的limit不能放在子查询内,limit不同与top,它可以规定范围...VW_Action 在mySql中修改为:select count() from VW_Action into @a; (6) MySQL视图的FROM子句不允许存在子查询,因此对于SQL Server...() 用不同的格式显示日期/时间 SQL Server Date 函数 GETDATE() 返回当前日期和时间 DATEPART() 返回日期/时间的单独部分 DATEADD() 在日期中添加或减去指定的时间间隔...DATEDIFF() 返回两个日期之间的时间 CONVERT() 用不同的格式显示日期/时间 4.2 Date 数据类型 MySQL 使用下列数据类型在数据库中存储日期或日期/时间值: DATE -...许多不同的子类型对这些类别中的每一个都是可用的,每个子类型支持不同大小的数据,并且 MySQL 允许我们指定数值字段中的值是否有正负之分或者用零填补。

    3.3K21

    SQL Server 索引内部结构:SQL Server 索引进阶 Level 10

    对于非聚集索引,每个行中包含一个条目的叶级别(除了已过滤的索引);每个条目由索引键列,可选的包含列和书签组成,这是聚集索引键列或RID(行ID)值。...它的目的是为SQL Server提供每个索引的单个页面入口点,以及从该页面到包含任何给定搜索关键字值的页面的简短遍历。 索引中的每个页面(无论其级别)都包含索引行或条目。...非叶级别条目仅包含索引键列和指向较低级别页面的指针。包含的列仅存在于叶级别条目中;它们不在非叶级别条目中进行。 除了根页面之外,索引中的每个页面都包含两个额外的指针。...这些指针在索引序列中指向下一页和前一页,处于同一级别。生成的双向页面链使SQL Server能够以升序或降序扫描任何级别的页面。 一个简单的例子 下面的图1所示的简单图帮助说明了这种树状结构的索引。...在AdventureWorks数据库中,没有索引的深度大于三。在具有非常大的表格或非常宽的索引键列的数据库中,可能会出现6或更大的深度。

    1.2K40

    SqlAlchemy 2.0 中文文档(七十二)

    1.3 版本及之前版本从未支持的行为,但仍然会产生特定效果,是重新利用列加载器选项,如defer()和with_expression() 在子查询中,以控制每个子查询的列子句中的 SQL 表达式。...另请参阅 select() 不再接受不同的构造参数,列按位置传递 select() 构造以“legacy”模式创建;关键字参数等 #5284 ### 所有 IN 表达式会动态为列表中的每个值渲染参数(例如...另请参阅 select() 不再接受不同的构造参数,列是按位置传递的 在“传统”模式下创建的 select() 构造;关键字参数等 #5284 所有 IN 表达式都会即时为列表中的每个值呈现参数(例如,...1.3 版本和之前版本从未支持的行为,但仍然会产生特定效果,即重新利用列加载器选项,如defer()和with_expression()在子查询中,以控制每个子查询的列子句中的 SQL 表达式。...一个在 1.3 版本和之前版本中从未支持过的行为,但仍然会产生特定效果的是重新利用列加载器选项,比如defer()和with_expression() 在子查询中,以控制哪些 SQL 表达式将出现在每个子查询的列子句中

    87610
    领券