INSERT
Gilt für: Databricks SQL Databricks Runtime
Fügt neue Zeilen in eine Tabelle ein und kürzt ggf. die Tabelle oder Partitionen. Sie geben die eingefügten Zeilen über Wertausdrücke oder das Ergebnis einer Abfrage an.
Databricks unterstützt INSERT
keine Hive Avro-Tabellen , wenn der timestamp-millis
Typ im Tabellenschema vorhanden ist.
Syntax
INSERT { OVERWRITE | INTO } [ TABLE ] table_name
[ PARTITION clause ]
[ ( column_name [, ...] ) | BY NAME ]
query
INSERT INTO [ TABLE ] table_name
REPLACE WHERE predicate
query
Hinweis
Wenn Sie INSERT INTO
verwenden, werden die Erzwingung und Entwicklung eines Delta-Tabellenschemas unterstützt.
Wenn der Datentyp einer Spalte nicht sicher in den Datentyp einer Delta-Tabelle umgeformt werden kann, wird eine Laufzeitausnahme ausgelöst.
Wenn die Schemaentwicklung aktiviert ist, können neue Spalten als letzte Spalten des Schemas (oder geschachtelte Spalten) vorhanden sein, damit das Schema weiterentwickelt werden kann.
Parameter
INTO
oderOVERWRITE
Wenn Sie
OVERWRITE
angeben, gilt:- Ohne
partition_spec
wird die Tabelle gekürzt, bevor die erste Zeile eingefügt wird. - Andernfalls werden alle Partitionen, die mit
partition_spec
übereinstimmen, vor dem Einfügen der ersten Zeile abgeschnitten.
Wenn Sie
INTO
angeben, sind alle eingefügten Zeilen zu den vorhandenen Zeilen additiv.- Ohne
-
Gibt die Tabelle an, in die eingefügt werden soll. Der Name darf keine temporale Spezifikation enthalten. Wenn die Tabelle nicht gefunden werden kann, löst Azure Databricks den Fehler TABLE_OR_VIEW_NOT_FOUND aus.
table_name
darf keine Fremdtabelle sein.Gilt für: Databricks SQL Databricks Runtime 16.0 und höher
table_name
kann eine Optionsspezifikation enthalten. -
Ein optionaler Parameter, der eine Zielpartition für die Einfügung angibt. Sie können die Partition auch nur teilweise angeben.
Wenn Sie eine statische Partition (
column = value
) angeben, darf diese Spalte in der Einfügespaltenliste nicht wiederholt werden.Wenn Sie eine dynamische Partition für
INSERT OVERWRITE
angeben, muss estable_name
sich um eine Delta Lake-Tabelle sein. ( column_name [, …] )
Eine optionale Liste von Spalten in der Tabelle. Der Einfüge-Befehl darf jede bestimmte Spalte aus der Tabelle höchstens einmal angeben.
Gilt für: Databricks SQL Databricks Runtime 12.2 LTS und höher
- Wenn dieser Befehl eine Spalte auslässt, weist Databricks SQL stattdessen den entsprechenden Standardwert zu.
- Wenn das Zieltabellenschema keinen Standardwert für die eingefügte Spalte definiert, weist Databricks SQL
NULL
zu, sofern die Spalte Nullwerte zulässt. Andernfalls löst Databricks SQL einen Fehler aus.
Die Angabe keiner Spaltenliste entspricht der Angabe aller Spalten, außer denen mit zugewiesenen Werten in der
PARTITION
-Klausel, in der in der Tabelle definierten Reihenfolge.BY NAME
Gilt für: Databricks SQL Databricks Runtime 13.3 LTS und höher
Wenn diese Klausel anstelle einer expliziten Spaltenliste verwendet wird, verwendet der Befehl die verfügbar gemachten Spaltennamen von
query
, um die Spaltenliste in der Reihenfolge vonquery
zu erzeugen. Wie bei einer expliziten Spaltenliste muss jede Spalte in der Zieltabelle vorhanden sein und darf nicht dupliziert werden. Wenn eine Spalte, die intable_name
vorhanden ist, nicht Teil der impliziten Spaltenliste ist, wird stattdessen der WertDEFAULT
verwendet.BY NAME
gleicht auch Attribute von Strukturen anhand des Namens ab.Keine Spalte in
query
darf mit einer in derPARTITION
-Klausel angegebenen Spalte oder einer generierten Spalte übereinstimmen.REPLACE WHERE boolean_expression
Gilt für: Databricks SQL Databricks Runtime 12.2 LTS und höher
Wenn es sich bei
table_name
um eine Delta Lake-Tabelle handelt, müssen Sie mitboolean_expression
übereinstimmende Zeilen löschen, bevor Sie Zeilen einfügen, die mit dem inquery
angegebenenboolean-expression
übereinstimmen. Zeilen inquery
, die nicht mitboolean_expression
übereinstimmen, werden ignoriert.boolean_expression
kann ein beliebiger Ausdruck sein, dessen Auswertung den ErgebnistypBOOLEAN
ergibt.Weitere Informationen finden Sie unter Beliebiges selektives Überschreiben mit replaceWhere.
-
Eine Abfrage, die die einzufügenden Zeilen erzeugt.
Sie müssen die Anzahl der von der Abfrage zurückgegebenen Spalten mit der angegebenen oder impliziten Einfügespaltenliste abgleichen.
Wenn ein Datentyp nicht sicher in den entsprechenden Spaltendatentyp umgeformt werden kann, wird eine Laufzeitausnahme ausgelöst.
Gilt für: Databricks SQL Databricks Runtime 11.3 LTS und höher
- Wenn
query
aus einer VALUES-Klausel besteht, kannexpression
DEFAULT
sein. - Wenn
query
aus einer SELECT-Klausel besteht, kannnamed_expression
DEFAULT
sein. DEFAULT
fügt den explizit definiertenDEFAULT
-Ausdruck der entsprechenden Spalte intable_name
ein, oderNULL
, wenn keiner definiert ist.
Wenn die Schemaentwicklung aktiviert ist, können neue Spalten als letzte Spalten des Schemas (oder geschachtelte Spalten) vorhanden sein, damit das Schema weiterentwickelt werden kann.
- Wenn
Beispiele
Inhalt dieses Abschnitts:
- INSERT INTO
- Einfügen mit einer Spaltenliste
- Einfügen mit einer Partitionsspezifikation und einer Spaltenliste
- INSERT mit der BY NAME-Klausel
- REPLACE WHERE
- INSERT OVERWRITE
INSERT INTO
INSERT using VALUES
> CREATE TABLE students (name VARCHAR(64), address VARCHAR(64) DEFAULT 'unknown', student_id INT)
PARTITIONED BY (student_id);
-- Single row insert using a `VALUES` clause specifying all columns.
> INSERT INTO students VALUES
('Amy Smith', '123 Park Ave, San Jose', 111111);
-- Single row insert using an implicit default for address
> INSERT INTO students(name, student_id) VALUES('Grayson Miller', 222222);
-- Single row insert using an explicit DEFAULT keyword for address
> INSERT INTO students VALUES('Youna Kim', DEFAULT, 333333);
-- Multi-row insert using a `VALUES` clause
> INSERT INTO students VALUES
('Bob Brown', '456 Taylor St, Cupertino', 444444),
('Cathy Johnson', '789 Race Ave, Palo Alto', 555555);
-- Multi-row insert using a mix of DEFAULT and literals
> INSERT INTO students VALUES
('Gwyneth Zhao', '120 Main St, Rockport', 666666),
('Jackson Peterson', DEFAULT, 777777);
> SELECT * FROM students;
name address student_id
---------------- ------------------------ ----------
Amy Smith 123 Park Ave, San Jose 111111
Grayson Miller unknown 222222
Youna Kim unknown 333333
Bob Brown 456 Taylor St, Cupertino 444444
Cathy Johnson 789 Race Ave, Palo Alto 555555
Gwyneth Zhao 120 Main St, Rockport 666666
Jackson Peterson unknown 777777
Einfügen mit einer Unterabfrage
-- Assuming the persons table has already been created and populated.
> SELECT * FROM persons;
name address ssn
------------- ------------------------- ---------
Dora Williams 134 Forest Ave, Melo Park 123456789
Eddie Davis 245 Market St, Milpitas 345678901
> INSERT INTO students PARTITION (student_id = 444444)
SELECT name, address FROM persons WHERE name = "Dora Williams";
> SELECT * FROM students;
name address student_id
------------- ------------------------- ----------
Amy Smith 123 Park Ave, San Jose 111111
Bob Brown 456 Taylor St, Cupertino 222222
Cathy Johnson 789 Race Ave, Palo Alto 333333
Dora Williams 134 Forest Ave, Melo Park 444444
-- Use an option specification to influence the write behavior
INSERT INTO t WITH ('write.split-size' = 10) SELECT * FROM s;
Einfügen mit einer TABLE
-Klausel
-- Assuming the visiting_students table has already been created and populated.
> SELECT * FROM visiting_students;
name address student_id
------------- --------------------- ----------
Fleur Laurent 345 Copper St, London 777777
Gordon Martin 779 Lake Ave, Oxford 888888
> INSERT INTO students TABLE visiting_students;
> SELECT * FROM students;
name address student_id
------------- ------------------------- ----------
Amy Smith 123 Park Ave,San Jose 111111
Bob Brown 456 Taylor St, Cupertino 222222
Cathy Johnson 789 Race Ave, Palo Alto 333333
Dora Williams 134 Forest Ave, Melo Park 444444
Fleur Laurent 345 Copper St, London 777777
Gordon Martin 779 Lake Ave, Oxford 888888
Einfügen in ein Verzeichnis
> CREATE TABLE students (name VARCHAR(64), address VARCHAR(64), student_id INT)
PARTITIONED BY (student_id)
LOCATION "/path/to/students_table";
> INSERT INTO delta.`/path/to/students_table` VALUES
('Amy Smith', '123 Park Ave, San Jose', 111111);
> SELECT * FROM students;
name address student_id
------------- ------------------------- ----------
Amy Smith 123 Park Ave, San Jose 111111
Einfügen mit einer Spaltenliste
> INSERT INTO students (address, name, student_id) VALUES
('Hangzhou, China', 'Kent Yao', 11215016);
> SELECT * FROM students WHERE name = 'Kent Yao';
name address student_id
--------- ---------------------- ----------
Kent Yao Hangzhou, China 11215016
Einfügen mit einer Partitionsspezifikation und einer Spaltenliste
> INSERT INTO students PARTITION (student_id = 11215017) (address, name) VALUES
('Hangzhou, China', 'Kent Yao Jr.');
> SELECT * FROM students WHERE student_id = 11215017;
name address student_id
------------ ---------------------- ----------
Kent Yao Jr. Hangzhou, China 11215017
INSERT mit der BY NAME-Klausel
> CREATE TABLE target(n INT, text STRING, s STRUCT<a INT, b INT>);
> INSERT INTO target BY NAME SELECT named_struct('b', 2, 'a', 1) AS s, 0 AS n, 'data' AS text;
> SELECT * FROM target;
0 data {"a":1,"b":2}
> CREATE OR REPLACE TABLE target(n INT, arr ARRAY<STRUCT<a INT, b INT>>);
> INSERT INTO target BY NAME SELECT array(named_struct('b', 2, 'a', 1)) AS arr, 0 AS n;
> INSERT INTO target BY NAME SELECT array(named_struct('b', 2, 'a', 1)) AS arr;
> SELECT * FROM target;
0 [{"a":1,"b":2}]
NULL [{"a":1,"b":2}]
> INSERT INTO target BY NAME SELECT array(named_struct('b', 2, 'a', 1)) AS arr, 0 AS badname;
Error
> INSERT INTO target BY NAME SELECT array(named_struct('b', 2, 'a', 1)) AS arr, 0 AS n, 1 AS n;
Error: INSERT_COLUMN_ARITY_MISMATCH.TOO_MANY_DATA_COLUMNS
REPLACE WHERE
> CREATE TABLE sales(tx_date DATE, amount INTEGER);
> INSERT INTO sales VALUES
(DATE'2022-10-01', 1234),
(DATE'2022-10-02', 2345),
(DATE'2022-10-03', 3456),
(DATE'2022-11-01', 3214);
-- Replace any rows with a transaction date in October 2022.
> INSERT INTO sales REPLACE WHERE tx_date BETWEEN '2022-10-01' AND '2022-10-31'
VALUES (DATE'2022-10-01', 1237),
(DATE'2022-10-02', 2378),
(DATE'2022-10-04', 2456),
(DATE'2022-10-05', 6328);
> SELECT * FROM sales ORDER BY tx_date;
tx_date amount
---------- ------
2022-10-01 1237
2022-10-02 2378
2022-10-04 2456
2022-10-05 6328
2022-11-01 3214
INSERT OVERWRITE
Einfügen mit einer VALUES
-Klausel
-- Assuming the students table has already been created and populated.
> SELECT * FROM students;
name address student_id
------------- ------------------------- ----------
Amy Smith 123 Park Ave, San Jose 111111
Bob Brown 456 Taylor St, Cupertino 222222
Cathy Johnson 789 Race Ave, Palo Alto 333333
Dora Williams 134 Forest Ave, Melo Park 444444
Fleur Laurent 345 Copper St, London 777777
Gordon Martin 779 Lake Ave, Oxford 888888
Helen Davis 469 Mission St, San Diego 999999
Jason Wang 908 Bird St, Saratoga 121212
> INSERT OVERWRITE students VALUES
('Ashua Hill', '456 Erica Ct, Cupertino', 111111),
('Brian Reed', '723 Kern Ave, Palo Alto', 222222);
> SELECT * FROM students;
name address student_id
---------- ----------------------- ----------
Ashua Hill 456 Erica Ct, Cupertino 111111
Brian Reed 723 Kern Ave, Palo Alto 222222
Einfügen mit einer Unterabfrage
-- Assuming the persons table has already been created and populated.
> SELECT * FROM persons;
name address ssn
------------- ------------------------- ---------
Dora Williams 134 Forest Ave, Melo Park 123456789
Eddie Davis 245 Market St,Milpitas 345678901
> INSERT OVERWRITE students PARTITION (student_id = 222222)
SELECT name, address FROM persons WHERE name = "Dora Williams";
> SELECT * FROM students;
name address student_id
------------- ------------------------- ----------
Ashua Hill 456 Erica Ct, Cupertino 111111
Dora Williams 134 Forest Ave, Melo Park 222222
Einfügen mit einer TABLE
-Klausel
-- Assuming the visiting_students table has already been created and populated.
> SELECT * FROM visiting_students;
name address student_id
------------- --------------------- ----------
Fleur Laurent 345 Copper St, London 777777
Gordon Martin 779 Lake Ave, Oxford 888888
> INSERT OVERWRITE students TABLE visiting_students;
> SELECT * FROM students;
name address student_id
------------- --------------------- ----------
Fleur Laurent 345 Copper St, London 777777
Gordon Martin 779 Lake Ave, Oxford 888888
Einfügen mit Überschreiben in ein Verzeichnis
> CREATE TABLE students (name VARCHAR(64), address VARCHAR(64), student_id INT)
PARTITIONED BY (student_id)
LOCATION "/path/to/students_table";
> INSERT OVERWRITE delta.`/path/to/students_table` VALUES
('Amy Smith', '123 Park Ave, San Jose', 111111);
> SELECT * FROM students;
name address student_id
------------- ------------------------- ----------
Amy Smith 123 Park Ave, San Jose 111111