gpt4 book ai didi

mysql - Where 子句中的 Number 与 Varchar2 的性能比较

转载 作者:行者123 更新时间:2023-11-29 16:40:42 24 4
gpt4 key购买 nike

我有一个表,其中 STATUS 列为 VARCHAR2(25)STATE 列为 VARCHAR2(2) > 还有更多栏目。

在从表中过滤记录时,我在查询中使用 STATUS 列和 STATE 列。

从选项卡中选择*,其中 STATUS = 'Active' AND STATE = 'WA';

由于 STATUSSTATE 列是 VARCHAR2 数据类型,我想引入新的两列 STATUS_ID 和表中的STATUS_ID,数据类型为NUMBERSTATUSSTATE 值替换为 STATUS_IDSTATE_IDNUMERIC 值。这样我就可以在 WHERE 子句中使用 NUMBER 列而不是 VARCHAR2 列。

从选项卡中选择 *,其中 STATUS_ID = 1 AND STATE_ID = 2;

我仅比较 NUMBERNUMBER 以及 VARCHAR2VARCHAR2 数据类型。查询中不存在隐式或显式的数据类型转换。

在 Oracle 数据库的 WHERE 子句中使用 NUMBER 数据类型代替 VARCHAR2 是否会提高性能?

我想知道 WHERE 子句中 NUMBER 数据类型是否比 VARCHAR2 数据类型具有更高的性能。这是真的吗?

谢谢。

最佳答案

性能将是相同的,因为 Oracle 将数字存储为打包字符串(与某些其他数据库不同)。在选择格式之前,您唯一应该考虑的是您将要对值使用的操作、转换或查找值所需的计算能力。

关于mysql - Where 子句中的 Number 与 Varchar2 的性能比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53357670/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com