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


当前回答

是的,但是只要你使用ASCII字符,即使是多字节字符集也会给出恰好30个字符的限制…所以除非你想把爱心和微笑的猫放在你的DB名字里,你的罚款…

其他回答

是的,但是只要你使用ASCII字符,即使是多字节字符集也会给出恰好30个字符的限制…所以除非你想把爱心和微笑的猫放在你的DB名字里,你的罚款…

更新:如上所述,在Oracle 12.2和更高版本中,最大对象名称长度现在是128字节。

这篇文章的其余部分适用于Oracle 12.1及以下:限制是30个字符(实际上是字节)。

但不要相信我的话;请自己试试(在Oracle 12.1或以下版本):

SQL> create table I23456789012345678901234567890 (my_id number);

Table created.



SQL> create table I234567890123456789012345678901(my_id number);


ERROR at line 1:

ORA-00972: identifier is too long

最大名称大小为30个字符,因为数据字典只允许存储30个字节

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

模式对象命名规则也可能有一些用处:

http://download.oracle.com/docs/cd/B19306_01/server.102/b14200/sql_elements008.htm#sthref723