我们的数据库中有一个存储过程,它通过在 where 条件下连接 30 列上的 2 个表来更新表。SQL 的一般格式为:
UPDATE Target
SET col1 = Source.col1
INNER JOIN Source
on
ISNULL(Target.Col2, '') = ISNULL(Source.Col2, '') and
ISNULL(Target.Col3, '') = ISNULL(Source.Col3, '') and
.
.
.
ISNULL(Target.Col31, '') = ISNULL(Source.Col31, '') and
这是查询计划。将其保存到您的 PC 并重新打开它,以便更好地扩展。
Source 表有 65M 记录,Target 有 165M。以前它曾经在几分钟内运行。考虑到查询的丑陋和潜在的低效,我觉得这很令人惊讶。这个月它运行了 1.5 小时,使用了 100% 的处理器,我们不得不杀死它。
任何建议如何即兴发挥以下查询并使其按时运行..?
我们在 30-col 连接条件中使用的一些列上有单列索引。
我知道 ISNULL 函数和 30 列上的连接是疯狂的,这是一个糟糕的设计。别怪我,我继承了这个经济。
不幸的是,没有时间重新设计。有什么建议么?