Oracle中表名和列名的最大长度是多少?


当前回答

描述all_tab_columns

将显示一个TABLE_NAME VARCHAR2(30)

注意:VARCHAR2(30)表示30个字节的限制,而不是30个字符的限制,因此,如果您的数据库被配置/设置为使用多字节字符集,可能会有所不同。

Mike

其他回答

Oracle数据库对象名称最大长度为30字节。

对象名称规则: http://docs.oracle.com/database/121/SQLRF/sql_elements008.htm

我正在使用Oracle 12c 12.1。但是,它似乎不允许列/表名超过30个字符。

阅读一个oracle页面,其中提到30个字节。 https://docs.oracle.com/database/121/SQLRF/sql_elements008.htm#SQLRF00223

在12c中,尽管all_tab_columns对Table_Name表示VARCHAR2(128),但它不允许超过30个字节的名称。

找到另一篇关于12c R2的文章,它似乎允许最多128个字符。 https://community.oracle.com/ideas/3338

描述all_tab_columns

将显示一个TABLE_NAME VARCHAR2(30)

注意:VARCHAR2(30)表示30个字节的限制,而不是30个字符的限制,因此,如果您的数据库被配置/设置为使用多字节字符集,可能会有所不同。

Mike

在Oracle 12.2及以上版本中,最大对象名称长度为128字节。

在Oracle 12.1及以下版本中,最大对象名称长度为30字节。

在Oracle 12.2上,你可以使用内置常量ORA_MAX_NAME_LEN, 设置为128字节(根据12.2) 在Oracle 12.1之前,最大大小为30字节。