RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 805114
Accepted
user282693
user282693
Asked:2020-03-27 04:17:46 +0000 UTC2020-03-27 04:17:46 +0000 UTC 2020-03-27 04:17:46 +0000 UTC

VARCHAR 和 VARCHAR2 的区别

  • 772

处理过Oracle数据库的每个人都知道,字符字段和变量必须声明为 VARCHAR2,而不是VARCHAR。

但这些数据类型似乎是同义词:

CREATE TABLE table1 (
  id number,
  text VARCHAR(10),
  text2 VARCHAR2(10)
);

Name  Null Type
----- ---- ------------
ID         NUMBER
TEXT       VARCHAR2(10)
TEXT2      VARCHAR2(10)

那么它们之间有什么区别呢?

sql
  • 3 3 个回答
  • 10 Views

3 个回答

  • Voted
  1. Best Answer
    Grundy
    2020-03-30T22:49:43Z2020-03-30T22:49:43Z

    目前它们是同义词。

    VARCHAR保留在将来Oracle支持和空字符串之间的区别,如标准中所述。NULLANSI

    VARCHAR2不区分NULL和空字符串,永远不会。

    如果您依赖空字符串并且NULL相同,请使用VARCHAR2.

    @Quassnoi答案的翻译

    • 4
  2. 0xdb
    2020-03-31T02:23:02Z2020-03-31T02:23:02Z

    目前,没有区别。类型VARCHAR是别名VARCHAR2,将替换为VARCHAR2.

    VARCHAR保留用于将来的版本以符合 ANSI/ISO-SQL 标准,Oracle不推荐这种类型。因此,每个人都使用该类型VARCHAR2,因为它的行为永远不会改变。

    与标准有什么区别VARCHAR2,有两个:

    • 空字符串被解释为NULL带长度NULL(不是 0)

    • NULL在字符串连接期间被忽略,在标准中这种连接的结果将是NULL

    为什么会发生(解释@JustinCave缩写):

    Oracle是数据库市场上非常老的供应商。在 SQL 尚未标准化的时候,Oracle理论家做出了一个设计决定,即数据库字段中的空字符串不包含信息,实际上是NULL.
    随着时间的推移,当 SQL 标准出现并确定NULL空字符串本质上有所不同时,已经有很多使用旧代码的用户没有考虑到这种差异。因此,Oracle面临着使现有代码无效或违反 SQL 标准的选择。根据Oracle的说法,一个破坏性较小的决定是保留数据类型VARCHAR以供更改和符合 SQL 标准并引入新的数据类型VARCHAR2,其行为保证不变。

    何时会做出预期的行为改变VARCHAR?

    这是版本 7中的情况,请注意短语 - “在 Oracle7 的下一个版本中”:

    VARCHAR 数据类型目前与 VARCHAR2 数据类型同义。建议您使用 VARCHAR2 而不是 VARCHAR。在 Oracle7 的未来版本中,与不同的比较语义相比,VARCHAR 可能是用于可变长度字符串的单独数据类型。

    而且,20 多年后,在19c 版中:

    不要使用 VARCHAR 数据类型。请改用 VARCHAR2 数据类型。尽管 VARCHAR 数据类型目前是 VARCHAR2 的同义词,但与不同的比较语义相比,VARCHAR 数据类型计划被重新定义为用于可变长度字符串的单独数据类型。

    • 3
  3. Равшан Абдулаев
    2020-03-30T17:04:24Z2020-03-30T17:04:24Z

    正确的答案是它们在使用方面没有区别;存储时,VARCHAR2 不会为 NULL 值保留空间,这与 VARCHAR 不同,即 用于存储(这对管理员很重要)。https://stackoverflow.com/questions/1171196/what-is-the-difference-between-varchar-and-varchar2-in-oracle的答案不正确。对于 VARCHAR 或 VARCHAR2 处理 NULL 没有区别(将来 VARCHAR 和 VARCHAR2 之间可能会有区别,但现在确实没有区别)。以下示例说明了相同的行为:

    DECLARE
      l_str VARCHAR(10):='';
      l_STR2 VARCHAR2(10) :='';
    BEGIN
        IF l_str IS NULL THEN 
             dbms_output.put_line('l_str is null'); 
            ELSE
             dbms_output.put_line('l_str is not null'); 
        END IF; 
    
        IF l_str2 IS NULL THEN 
             dbms_output.put_line('l_str2 is null'); 
            ELSE
             dbms_output.put_line('l_str2 is not null');    
        END IF;
    END;
    
    • -2

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5