我认为带有串联的版本实际上总是比较慢。
如果您要比较的任何列中的任何一个都有索引,则数据库通常将能够使用索引来优化联接。比较串联时,它必须执行全表扫描,因为计算结果不会出现在索引中。
即使没有为列建立索引,数据库仍可以更有效地执行比较。它一次比较一对列,并且一旦其中一个比较失败就可以停止。使用串联时,它必须首先合并两行中的所有列,然后进行字符串比较。
最后,如果任何列为数字,则串联将需要将数字转换为字符串的附加步骤。

我认为带有串联的版本实际上总是比较慢。
如果您要比较的任何列中的任何一个都有索引,则数据库通常将能够使用索引来优化联接。比较串联时,它必须执行全表扫描,因为计算结果不会出现在索引中。
即使没有为列建立索引,数据库仍可以更有效地执行比较。它一次比较一对列,并且一旦其中一个比较失败就可以停止。使用串联时,它必须首先合并两行中的所有列,然后进行字符串比较。
最后,如果任何列为数字,则串联将需要将数字转换为字符串的附加步骤。