Was ist die maximale Länge eines Tabellennamens und eines Spaltennamens in Oracle?
oracle
name-length
robertkroll
quelle
quelle
Bringe einem Mann das Fischen bei
Beachten Sie den Datentyp und die Größe
quelle
describe user_mview_logs
zurückgegeben,LOG_TABLE VARCHAR2(128)
aber wenn Sie etwas versuchen, das sich 30 Zeichen oder mehr für einen materialisierten Ansichtsprotokollnamen nähert, erhalten Sie einige ziemlich rätselhafte Ergebnisse.BESCHREIBEN Sie all_tab_columns
zeigt einen TABLE_NAME VARCHAR2 (30)
Hinweis VARCHAR2 (30) bedeutet eine 30-Byte-Beschränkung, keine 30-Zeichen-Beschränkung, und kann daher unterschiedlich sein, wenn Ihre Datenbank für die Verwendung eines Multibyte-Zeichensatzes konfiguriert / eingerichtet ist.
Mike
quelle
Richtig, aber solange Sie ASCII-Zeichen verwenden, würde selbst ein Multibyte-Zeichensatz eine Beschränkung von genau 30 Zeichen ergeben. Wenn Sie also keine Herzen und lächelnde Katzen in Ihre DB-Namen einfügen möchten, ist Ihre Geldstrafe ...
quelle
30 Zeichen (Bytes, wie bereits erwähnt).
Aber vertraue mir nicht; Probieren Sie es selbst aus:
Aktualisiert: Wie oben angegeben, beträgt die maximale Länge des Objektnamens in Oracle 12.2 und höher jetzt 128 Byte.
quelle
Die Regeln für die Benennung von Schemaobjekten können auch von Nutzen sein:
http://download.oracle.com/docs/cd/B19306_01/server.102/b14200/sql_elements008.htm#sthref723
quelle
In der 10g-Datenbank, mit der ich mich befasse, weiß ich, dass Tabellennamen maximal 30 Zeichen lang sind. Konnte Ihnen nicht sagen, wie lang der Spaltenname ist (aber ich weiß, dass er> 30 ist).
quelle
Die maximale Namensgröße beträgt 30 Zeichen, da das Datenwörterbuch nur 30 Byte speichern kann
quelle
Ein
Oracle 12.2
, Sie können die integrierte Konstante verwenden,ORA_MAX_NAME_LEN
die auf 128 Byte (gemäß 12.2) festgelegt ist. Vor derOracle 12.1
maximalen Größe waren es 30 Byte.quelle
Die maximale Länge der Oracle-Datenbankobjektnamen beträgt 30 Byte .
Regeln für Objektnamen: http://docs.oracle.com/database/121/SQLRF/sql_elements008.htm
quelle
Ich arbeite an Oracle 12c 12.1. Es scheint jedoch nicht mehr als 30 Zeichen für Spalten- / Tabellennamen zuzulassen.
Lesen Sie eine Orakelseite durch, auf der 30 Bytes erwähnt werden. https://docs.oracle.com/database/121/SQLRF/sql_elements008.htm#SQLRF00223
In 12c wird in den all_tab_columns zwar VARCHAR2 (128) für Table_Name angegeben, es werden jedoch nicht mehr als 30 Byte Name zugelassen.
Es wurde ein weiterer Artikel über 12c R2 gefunden, der anscheinend bis zu 128 Zeichen zulässt. https://community.oracle.com/ideas/3338
quelle
Die maximale Länge des Tabellen- und Spaltennamens beträgt 128 Byte oder 128 Zeichen. Diese Grenze gilt für die Verwendung von Benutzern der Sybase-Datenbank. Ich habe diese Antwort gründlich überprüft, so dass ich diese Antwort sicher gepostet habe.
quelle