当前位置: 首页 > 面试题库 >

SELECT类型查询是唯一可以嵌套的类型吗?

叶智
2023-03-14
问题内容

是否可以将非选择查询(更新,插入,删除)嵌入到另一个查询中?

诸如此类(select内的插入)

A single query:

select such,and,such from .... where .... insert into .... ;

问题答案:

基本答案

Postgres中CTE* (公用表表达式)

*(就像在除MySQL外的任何主要现代RDBMS中一样)。
从9.1版开始,其中包括修改数据的CTE。这些可以“嵌套”。
更新:MySQL 8.0最终添加了CTE。

子查询
不同,CTE构成了优化障碍。查询计划程序无法将琐碎的命令内联到主命令中,也无法在主查询和CTE之间重新排序联接。子查询也可能如此。取决于性能,它的性能可能(非常)好(坏)。
无论哪种方式,CTE都比子查询需要更多的开销(性能成本)。

您未要求的详细信息

您的问题非常基本,以上内容足以回答。但是,我将为高级用户添加一些内容(以及一个显示语法的代码示例)。

查询的所有CTE基于数据库的 相同快照 。下一个CTE可以重用以前CTE 的 输出
(内部临时表),但是对其他CTE而言,对基础表的影响是不可见的。多热膨胀系数的顺序是任意的 ,除非
事情返回了RETURNINGfor子句INSERTUPDATEDELETEirrelvant为-
SELECT,因为它不会改变任何东西,并从快照只是读取。

这可能会对多个更新产生微妙影响,这些更新会影响同一行。只有 一个 更新可以影响每一行。哪一个受CTE顺序的影响。

尝试预测结果:

CREATE TEMP TABLE t (t_id int, txt text);
INSERT INTO t VALUES (1, 'foo'), (2, 'bar'), (3, 'baz');

WITH sel AS (SELECT * FROM t)
   , up1 AS (UPDATE t SET txt = txt || '1' WHERE t_id = 1 RETURNING *)
   , up2 AS (UPDATE t SET txt = t.txt || '2'
             FROM   up1
             WHERE  up1.t_id = t.t_id
             RETURNING t.*)
   , ins AS (INSERT INTO t VALUES (4, 'bamm'))
   , up3 AS (UPDATE t SET txt = txt || '3' RETURNING *)
SELECT 'sel' AS source, * FROM sel
UNION ALL
SELECT 'up1' AS source, * FROM up1
UNION ALL
SELECT 'up2' AS source, * FROM up2
UNION ALL
SELECT 'up3' AS source, * FROM up3
UNION ALL
SELECT 't'   AS source, * FROM t;

SQL小提琴

别失望,我怀疑这里有很多人可以做到。:)
要点: 避免 CTE中的命令冲突。



 类似资料:
  • 本页包含内容: 嵌套类型实例 嵌套类型的引用 枚举类型常被用于实现特定类或结构体的功能。也能够在有多种变量类型的环境中,方便地定义通用类或结构体来使用,为了实现这种功能,Swift允许你定义嵌套类型,可以在枚举类型、类和结构体中定义支持嵌套的类型。 要在一个类型中嵌套另一个类型,将需要嵌套的类型的定义写在被嵌套类型的区域{}内,而且可以根据需要定义多级嵌套。 嵌套类型实例 下面这个例子定义了一个结

  • 我试图在ElasticSearch中构建以下查询: 是否可以使用elasticsearch使用“或真”部分,或者有其他方法构造查询以给出相同的结果? 我有一组文档,比如说10个,都匹配tag1,这10个文档中的一些还匹配tag2和tag3,如果是这样,我将使用命名查询来告诉我哪些文档匹配tag2和tag3(匹配tag2和tag3的文档是匹配tag1的文档的子集)。 但是,即使没有匹配tag2或ta

  • 我有一个不那么独特的需求,但我只是找到了正确的术语来搜索,因为我只得到如何查询列表/数组字段或嵌套元素的结果。 提前感谢所有的帮助。

  • 我试图为一个业务场景制定一个查询,其中我们有一个名为“types”的嵌套字段类型(即类似于字符串的ArrayList)。下面是以“类型”作为字段之一的索引文档示例。 文件1:{“类型”:[{“标签”:“对话”,},{“标签”:“暴力”,},{“标签”:“语言”,}} 文档2:{“类型”:[{“标签”:“对话框”,}} 现在,要求搜索查询最多匹配字段值中的一个值,即如果用户搜索“对话框”,那么它应该

  • 我有一个模板结构。struct foo有嵌套类型。 我想使指针可哈希,这将适合

  • 问题内容: 这个错误是什么意思? 嵌套类型HelloWorld无法隐藏封闭类型 其中HelloWorld是Java文件名。这是您需要的代码: 问题答案: 您已经两次定义了HelloWorld类。删除一个级别,就可以了。