- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们最近升级到 SQL Server 2016,我们开始看到以前从未见过的错误。
该错误与升级完全无关,但我想值得一提。
我们的场景如下(以更简单的查询方式显示):
DROP TABLE IF EXISTS dbo.TestTable
CREATE TABLE dbo.TestTable
(
AsAt DATETIME,
Key1 INT,
Key2 INT
)
CREATE CLUSTERED INDEX ixc_TestTable ON dbo.TestTable (AsAt)
GO
CREATE UNIQUE NONCLUSTERED INDEX ixu_TestTable ON dbo.TestTable (AsAt, Key1, Key2)
GO
DELETE FROM dbo.TestTable WHERE Key1 = 1 AND AsAt = '20180131'
INSERT INTO dbo.TestTable
( AsAt, Key1, Key2 )
VALUES
( '20180131',
1, -- Key1 - int
3 -- Key2 - int
)
INSERT INTO dbo.TestTable
( AsAt, Key1, Key2 )
SELECT
AsAt,
Key1,
130
FROM
dbo.TestTable AS tt
UNION ALL
SELECT
AsAt,
Key1,
129
FROM
dbo.TestTable AS tt
遗憾的是这个小例子并没有失败
在现实世界场景中,第一个 INSERT
正在插入几千条记录,并且 SELECT
在UNION ALL
涉及多个JOINS
但他们的关键是他们SELECT
从我们插入的表中。
我们看到的是,在某些情况下 IXU
约束失败,尝试为 Key2 = 129
插入重复项.
如果我们继续运行查询,我们会在一些运行成功的地方运行,在一些运行失败的地方运行。
这让我们认为问题在于第一个 SELECT
正在插入然后 SELECTED
由第二个插入,导致重复。
有两个修复看起来每次都能使查询正常工作:
WHERE Key2 <> 130
在第二个 SELECT
SELECT
UNION ALL
进入#temp
表,然后 INSERT
目标表中的结果我们会认为 SELECT UNION ALL
INSERT
的一部分应该以原子方式执行,然后结果 INSERT
在表中。我们的想法错了吗?
即。 UNION ALL 的第二个选择将看不到第一个 SELECT 中插入的记录。
额外信息:
READ COMMITED
TRANSACTION
中运行MAXDOP 1
查询不会改变任何东西INSERT
节点COLUMN STORE
所涉及表的索引更新:我们一直在尝试在没有列存储索引的情况下进行查询,尽管它们速度较慢但不会失败。当我们再次将列存储索引放回原处时,我们会在合理的迭代次数 (<200)
中得到错误最佳答案
通过包装 UNION ALL 语法,这可以消除观察到的任何执行计划异常。我无法复制,所以我无法确定。但它肯定具有“无害”级别的影响。
INSERT INTO dbo.TestTable
( AsAt, Key1, Key2 )
SELECT u.*
FROM (
SELECT AsAt, Key1, 130 As Key2
FROM dbo.TestTable AS tt
UNION ALL
SELECT AsAt, Key1, 129
FROM dbo.TestTable AS tt
) u
关于sql - Sql Server 2016 中 INSERT SELECT UNION ALL 的原子性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48562662/
自从我的问题here无法自信地回答,我在这里再次询问,希望有人确切知道: 指向 union 的指针和包含指向其元素的指针的 union 之间有什么区别(除了语法之外)吗? this中生成的程序集示例是
在 C 语言中,是否可以在另一个 union 体中定义一个 union 体?如果不是,为什么不可能?或者如果可以,可以在哪里使用? 最佳答案 假设您要定义: union myun { int x;
在 C 中,是否可以在另一个 union 中定义一个 union ?如果不是,为什么不可能?或者如果是,它可以在哪里使用? 最佳答案 假设你想定义: union myun { int x; s
我正在阅读一些代码并发现如下内容: typedef union { int int32; int boolean; time_t date; char *string;
我正在学习Lua,我更愿意使用冒号(:)作为方法。不幸的是,它并非在所有地方都有效。看我的代码: 设置= {} 本地mt = {} 函数Set:new(m) 本地集= {} setmetatable(
我遇到了一些性能问题,我有如下查询: SELECT * FROM Foo UNION SELECT * FROM Boo UNION SELECT * FROM Koo 我确信 Koo 不会返回任何重
This question already has answers here: C++ Structure Initialization (16个答案) 上个月关闭。 我正在尝试将一些用于嵌入式目标的
UNION 和 UNION ALL 有什么区别? 最佳答案 UNION 删除重复记录(结果中的所有列都相同),UNION ALL 则不会。 使用 UNION 而不是 UNION ALL 时会影响性能,
我想在两个表上使用联合运算符。我希望结果集消除由联合创建的重复值,但不消除表中预先存在的重复值。考虑这段代码... select b from (values (1), (2), (2
我知道 UNION 会删除重复项,但即使没有重复项也会更改结果顺序。 我有两个 select 语句,任何地方都没有 order by 语句 我想将它们合并或不合并(全部) 即 SELECT A UNI
基本上,我有一个 struct foo { /* variable denoting active member of union */ enum whichmembe
我有一个大规模查询,用于对许多表(每个表有数千行)执行 UNION ALL,然后在返回之前输出到临时表。 旧形式: SELECT * FROM (SELECT `a` AS `Human rea
UNION 和 UNION ALL 有什么区别? 最佳答案 UNION 删除重复记录(结果中的所有列都相同),UNION ALL 则不会。 使用 UNION 而不是 UNION ALL 时会影响性能,
如果我有两个 union 行结构: struct A { A() {} ~A() {} union { vector vi; vector db
考虑下面的代码,我已经写了: #include #include union myAccess { uint16_t access16; struct { uint
我想弄清楚你从 C99 中对齐变量的地役权中得到了什么: Exception to strict aliasing rule in C from 6.5.2.3 Structure and union
我正在通过 UNION 或 UNION ALL 从多个表中选择一列外键。 当重复无关紧要时,通常建议使用 UNION ALL 而不是 UNION 来解决性能问题。但是,在我的调用 PHP 脚本中,循环
在 C++ 中,union 可以包含静态成员,在类的情况下,这些成员属于一个类,因此对所有对象都是通用的。 union U { long l; int i; static long
任何人都可以提及普通和匿名 union (或结构)之间的区别吗?我刚找到一个: 不能在匿名 union 中定义函数。 最佳答案 您不需要点运算符“.”访问匿名 union 元素。 #include
我可能把这个复杂化了.. 我正在尝试在 Arduino 上用 C 语言为嵌入式应用程序制作一个相当可重用的分层菜单系统。我有结构来表示不同类型的菜单项,包括那些子菜单,以及这些菜单项的 union 是
我是一名优秀的程序员,十分优秀!