¿Cuál es la longitud máxima de un nombre de tabla y columna en Oracle?
oracle
name-length
robertkroll
fuente
fuente
Enseñar a un hombre a pescar
Observe el tipo de datos y el tamaño
fuente
describe user_mview_logs
regresa,LOG_TABLE VARCHAR2(128)
pero si intenta algo que se aproxime a 30 caracteres o más para un nombre de registro de vista materializado, obtendrá resultados bastante desconcertantes.DESCRIBA all_tab_columns
mostrará un TABLE_NAME VARCHAR2 (30)
Nota VARCHAR2 (30) significa una limitación de 30 bytes, no una limitación de 30 caracteres, y por lo tanto puede ser diferente si su base de datos está configurada / configurada para usar un juego de caracteres multibyte.
Miguel
fuente
Correcto, pero siempre que use caracteres ASCII, incluso un conjunto de caracteres multibyte aún le daría una limitación de exactamente 30 caracteres ... así que, a menos que quiera poner corazones y gatos sonrientes en sus nombres DB, está bien ...
fuente
30 caracteres (bytes, realmente, como se ha dicho).
Pero no confíes en mí; prueba esto por ti mismo:
Actualizado: como se indicó anteriormente, en Oracle 12.2 y versiones posteriores, la longitud máxima del nombre del objeto es ahora de 128 bytes.
fuente
Las reglas de nomenclatura de objetos de esquema también pueden ser de alguna utilidad:
http://download.oracle.com/docs/cd/B19306_01/server.102/b14200/sql_elements008.htm#sthref723
fuente
En la base de datos de 10g con la que estoy tratando, sé que los nombres de las tablas tienen un máximo de 30 caracteres. No podría decirte cuál es la longitud del nombre de la columna (pero sé que es> 30).
fuente
El tamaño máximo del nombre es de 30 caracteres debido al diccionario de datos que permite el almacenamiento solo para 30 bytes.
fuente
Encendido
Oracle 12.2
, puede usar la constante incorporadaORA_MAX_NAME_LEN
, establecida en 128 bytes (según 12.2) Antes de que elOracle 12.1
tamaño máximo fuera de 30 bytes.fuente
La longitud máxima de los nombres de objeto de la base de datos de Oracle es de 30 bytes .
Reglas de nombre de objeto: http://docs.oracle.com/database/121/SQLRF/sql_elements008.htm
fuente
Estoy trabajando en Oracle 12c 12.1. Sin embargo, no parece que permita más de 30 caracteres para los nombres de columna / tabla.
Lea una página de Oracle que menciona 30 bytes. https://docs.oracle.com/database/121/SQLRF/sql_elements008.htm#SQLRF00223
En 12c, aunque las columnas all_tab_columns dicen VARCHAR2 (128) para Table_Name, no permite un nombre de más de 30 bytes.
Encontré otro artículo sobre 12c R2, que parece estar permitiendo esto hasta 128 caracteres. https://community.oracle.com/ideas/3338
fuente
La longitud máxima de la tabla y el nombre de la columna es de 128 bytes o 128 caracteres. Este límite es para usar usuarios de la base de datos sybase. Verifiqué esta respuesta a fondo, por lo que he publicado esta respuesta con confianza.
fuente