Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Aplica-se a:
SQL do Databricks
Databricks Runtime
Altera o esquema ou as propriedades de uma tabela.
O ALTER TABLE comando não tem suporte para tabelas temporárias. Um erro será retornado se o ALTER TABLE comando for aplicado a uma tabela temporária. Se a tabela estiver armazenada em cache, o comando limpará os dados armazenados em cache da tabela e todos os dependentes que se referem a ela. O cache será preenchido de forma ociosa quando a tabela ou os dependentes forem acessados da próxima vez.
Em tabelas estrangeiras, você só pode executar ALTER TABLE SET OWNER e ALTER TABLE RENAME TO.
Permissões necessárias
Se você usar o Catálogo do Unity, deverá ter MODIFY permissão para:
ALTER COLUMNADD COLUMNDROP COLUMNSET TBLPROPERTIESUNSET TBLPROPERTIESPREDICTIVE OPTIMIZATION
Se você usar o Unity Catalog, precisará ter a permissão MANAGE ou propriedade para:
SET OWNER TO
Todas as outras operações exigem a propriedade da tabela.
Sintaxe
ALTER TABLE table_name
{ RENAME TO clause |
ADD COLUMN clause |
ALTER COLUMN clause |
DROP COLUMN clause |
RENAME COLUMN clause |
DEFAULT COLLATION clause |
ADD CONSTRAINT clause |
DROP CONSTRAINT clause |
DROP FEATURE clause |
ADD PARTITION clause |
DROP PARTITION clause |
PARTITION SET LOCATION clause |
RENAME PARTITION clause |
RECOVER PARTITIONS clause |
SET { ROW FILTER clause } |
DROP ROW FILTER |
SET TBLPROPERTIES clause |
UNSET TBLPROPERTIES clause |
SET SERDE clause |
SET LOCATION clause |
SET OWNER TO clause |
SET SERDE clause |
SET TAGS clause |
UNSET TAGS clause |
CLUSTER BY clause |
PREDICTIVE OPTIMIZATION clause}
Parâmetros
-
Identifica a tabela que está sendo alterada. O nome não deve incluir uma especificação temporal ou especificação de opções. Se a tabela não puder ser encontrada, o Azure Databricks gerará um erro TABLE_OR_VIEW_NOT_FOUND.
RENAME TOto_table_nameRenomeia a tabela.
-
Identifica o novo nome da tabela. O nome não deve incluir uma especificação temporal ou especificação de opções.
Para tabelas do Catálogo do Unity,
to_table_namedeve estar dentro do mesmo catálogo quetable_name. Para outras tabelas, oto_table_namedeve estar dentro do mesmo esquema que otable_name.Se
to_table_namenão for qualificado, ele será automaticamente qualificado com o esquema atual.
> ALTER TABLE student RENAME TO student_info;-
-
Adiciona uma ou mais colunas à tabela.
Quando você adiciona uma coluna a uma tabela delta lake existente, não é possível definir um
DEFAULTvalor. Todas as colunas adicionadas às tabelas delta lake são tratadas comoNULLpara linhas existentes. Depois de adicionar uma coluna, opcionalmente, você pode definir um valor padrão para novas linhas usandoALTER COLUMN.> DESCRIBE StudentInfo; col_name data_type comment ----------------------- --------- ------- name string NULL rollno int NULL age int NULL > ALTER TABLE StudentInfo ADD columns (LastName string, DOB timestamp); -- After adding new columns to the table > DESCRIBE StudentInfo; col_name data_type comment ----------------------- --------- ------- name string NULL rollno int NULL LastName string NULL DOB timestamp NULL age int NULL -- Optionally set a default value for new rows > ALTER TABLE StudentInfo ALTER COLUMN LastName SET DEFAULT 'unknown';
-
Altera uma propriedade ou o local de uma coluna.
> DESCRIBE StudentInfo; col_name data_type comment ----------------------- --------- ------- name string NULL rollno int NULL LastName string NULL DOB timestamp NULL age int NULL > ALTER TABLE StudentInfo ALTER COLUMN name COMMENT "new comment"; -- After altering the column > DESCRIBE StudentInfo; col_name data_type comment ----------------------- --------- ----------- name string new comment rollno int NULL LastName string NULL DOB timestamp NULL age int NULLAltere várias colunas em uma única instrução:
-- Create a table with 3 columns > CREATE TABLE my_table (num INT, str STRING, bool BOOLEAN) TBLPROPERTIES('delta.feature.allowColumnDefaults' = 'supported') > DESCRIBE TABLE my_table; col_name data_type comment -------- --------- ------- num int null str string null bool boolean null -- Update comments on multiple columns > ALTER TABLE table ALTER COLUMN num COMMENT 'number column', str COMMENT 'string column'; > DESCRIBE TABLE my_table; col_name data_type comment -------- --------- ------------- num int number column str string string column bool boolean null -- Can mix different types of column alter > ALTER TABLE table ALTER COLUMN bool COMMENT 'boolean column', num AFTER bool, str AFTER num, bool SET DEFAULT true; > DESCRIBE TABLE my_table; col_name data_type comment -------- --------- -------------- bool boolean boolean column num int number column str string string column -
Remover uma ou mais colunas ou campos em uma tabela Delta Lake.
-
Renomeia uma coluna ou campo em uma tabela do Delta Lake.
> ALTER TABLE StudentInfo RENAME COLUMN name TO FirstName; -- After renaming the column > DESCRIBE StudentInfo; col_name data_type comment ----------------------- --------- ----------- FirstName string new comment rollno int NULL LastName string NULL DOB timestamp NULL age int NULL
-
Adiciona uma restrição de verificação, uma restrição de chave estrangeira informativa ou uma restrição de chave primária informativa à tabela.
As chaves estrangeiras e as chaves primárias não têm suporte para tabelas no catálogo
hive_metastore. DEFAULT COLLATIONCollation_nameAplica-se a:
Databricks SQL
Databricks Runtime 16.3 e versões superioresAltera a ordenação padrão da tabela para novas
STRINGcolunas. As colunas existentes não são afetadas por essa cláusula. Para alterar a ordenação de uma coluna existente, useALTER TABLE ... ALTER COLUMN ... COLLATE collation_name.
-
Remove uma chave primária, uma chave estrangeira ou uma restrição de verificação da tabela.
DROP FEATURE feature_name [ TRUNCATE HISTORY ]Aplica-se a:
Databricks Runtime 14.3 LTS e superiorO suporte herdado para
DROP FEATUREestá disponível a partir do Databricks Runtime 14.3 LTS. Para a documentação de funcionalidades herdadas, consulte Drop Delta table features (legacy).Aplica-se a:
Databricks SQL
Databricks Runtime 16.3 e versões superioresO Azure Databricks recomenda o uso do Databricks Runtime 16.3 e superior para todos os
DROP FEATUREcomandos, o que substitui o comportamento herdado.Remove um recurso de uma tabela do Delta Lake.
Remover uma funcionalidade pode resultar na adição da funcionalidade de
checkpointProtectiongravador ao protocolo de tabelas. Para obter mais informações, consulte Os recursos da tabela Drop Delta e os recursos de tabela para compatibilidade de protocolo.feature_nameO nome de um recurso na forma de um literal
STRINGou identificador, que deve ser compreendido pelo Azure Databricks e ter suporte na tabela.Se o recurso não estiver presente na tabela, o Azure Databricks aciona DELTA_FEATURE_DROP_FEATURE_NOT_PRESENT.
HISTÓRICO DE TRUNCADOS
Remoção de funcionalidades por meio de truncamento do histórico. Isso requer um processo de dois estágios:
A remoção de recursos truncando o histórico requer um processo de duas etapas:
A primeira invocação limpa os rastreamentos do recurso e informa sobre o êxito parcial.
Em seguida, aguarde o término do período de retenção antes de executar novamente a instrução para concluir a remoção.
Se você iniciar a segunda invocação muito cedo, o Azure Databricks gerará DELTA_FEATURE_DROP_WAIT_FOR_RETENTION_PERIOD ou DELTA_FEATURE_DROP_HISTORICAL_VERSIONS_EXIST.
Truncar o histórico da tabela limita sua capacidade de executar DESCRIBE HISTORY e executar consultas de viagem no tempo.
-- Drop the "deletion vectors" from a Delta table > ALTER TABLE my_table DROP FEATURE deletionVectors; -- 24 hours later > ALTER TABLE my_table DROP FEATURE deletionVectors TRUNCATE HISTORY;-
Adiciona uma ou mais partições à tabela.
> SHOW PARTITIONS StudentInfo; partition --------- age=11 age=12 age=15 > ALTER TABLE StudentInfo ADD IF NOT EXISTS PARTITION (age=18); -- After adding a new partition to the table > SHOW PARTITIONS StudentInfo; partition --------- age=11 age=12 age=15 age=18 -- Adding multiple partitions to the table > ALTER TABLE StudentInfo ADD IF NOT EXISTS PARTITION (age=18) PARTITION (age=20); > SHOW PARTITIONS StudentInfo; partition --------- age=11 age=12 age=15 age=18 age=20 -
Descarta uma ou mais partições da tabela.
> SHOW PARTITIONS StudentInfo; partition --------- age=11 age=12 age=15 age=18 > ALTER TABLE StudentInfo DROP IF EXISTS PARTITION (age=18); -- After dropping the partition of the table > SHOW PARTITIONS StudentInfo; partition --------- age=11 age=12 age=15 -
Define o local de uma partição.
> ALTER TABLE dbx.tab1 PARTITION (a='1', b='2') SET LOCATION '/path/to/part/ways'; -
Substitui as chaves de uma partição.
> SHOW PARTITIONS StudentInfo; partition --------- age=10 age=11 age=12 > ALTER TABLE default.StudentInfo PARTITION (age='10') RENAME TO PARTITION (age='15'); -- After renaming Partition > SHOW PARTITIONS StudentInfo; partition --------- age=11 age=12 age=15 -
Instrui o Azure Databricks a verificar o local da tabela e adicionar todos os arquivos à tabela que foram adicionados diretamente ao sistema de arquivos.
Cláusula
SETROW FILTERAplica-se a:
SQL do Databricks
Databricks Runtime 12.2 LTS e versões posteriores
Somente Catálogo do UnityAdiciona uma função de filtro de linha à tabela. Todas as consultas subsequentes à tabela recebem um subconjunto de linhas onde a função avalia como o valor booliano TRUE. Isso pode ser útil para fins de controle de acesso refinado, em que a função pode inspecionar a identidade ou as associações de grupo do usuário que a invocou para determinar se deseja filtrar algumas linhas.
DROP ROW FILTERAplica-se a:
Somente Catálogo do UnityDescarta o filtro de linha da tabela, se houver. Consultas futuras retornarão todas as linhas da tabela sem nenhuma filtragem automática.
-
Configura ou reconfigura uma ou mais propriedades definidas pelo usuário.
> ALTER TABLE dbx.tab1 SET TBLPROPERTIES ('winner' = 'loser'); -
Remove uma ou mais propriedades definidas pelo usuário.
> ALTER TABLE dbx.tab1 UNSET TBLPROPERTIES ('winner'); SET SERDEAplica-se a:
Databricks RuntimeEspecifica a classe serDe (serializador/desserializador) usada para ler e gravar dados em uma tabela em formato Hive. Você também pode configurar as propriedades do SerDe com
WITH SERDEPROPERTIES.> ALTER TABLE test_tab SET SERDE 'org.apache.hadoop.hive.serde2.columnar.LazyBinaryColumnarSerDe'; > ALTER TABLE dbx.tab1 SET SERDE 'org.apache.hadoop' WITH SERDEPROPERTIES ('k' = 'v', 'kay' = 'vee');SET LOCATIONMove o local de uma tabela.
SET LOCATION pathLOCATION pathpathdeve ser uma literal deSTRING. Especifica o novo local da tabela.Os arquivos no local original não serão movidos para o novo local.
[ SET ] OWNER TOentidadeTransfere a propriedade da tabela para
principal.Aplica-se a:
SQL do Databricks
Databricks Runtime 11.3 LTS e versões posterioresSETé permitido como uma palavra-chave opcional.SET TAGS ( { tag_name = tag_value } [, ...] )Aplica-se a:
SQL do Databricks
Databricks Runtime 13.3 LTS e versões posterioresAplica tags à tabela. Você precisa ter a permissão
APPLY TAGpara adicionar tags à tabela.nome_da_tag
Um literal
STRING. Otag_namedeve ser exclusivo na tabela ou coluna.tag_value
Um literal
STRING.
-- Applies three tags to the table named `test`. > ALTER TABLE test SET TAGS ('tag1' = 'val1', 'tag2' = 'val2', 'tag3' = 'val3'); -- Applies three tags to table `main.schema1.test` column `col1`. > ALTER TABLE main.schema1.test ALTER COLUMN col1 SET TAGS ('tag1' = 'val1', 'tag2' = 'val2', 'tag3' = 'val3');UNSET TAGS ( tag_name [, ...] )Aplica-se a:
SQL do Databricks
Databricks Runtime 13.3 LTS e versões posterioresRemove as tags da tabela. Você precisa ter a permissão
APPLY TAGpara remover tags da tabela.nome_da_tag
Um literal
STRING. Otag_namedeve ser exclusivo na tabela ou coluna.
-- Removes three tags from the table named `test`. > ALTER TABLE test UNSET TAGS ('tag1', 'tag2', 'tag3'); -- Removes three tags from table `main.schema1.test` column `col1`. > ALTER TABLE main.schema1.test ALTER COLUMN col1 UNSET TAGS ('tag1', 'tag2', 'tag3');Cláusula CLUSTER BY
Aplica-se a:
SQL do Databricks
Databricks Runtime 13.3 LTS e versões posterioresAdiciona, altera ou descarta a estratégia de clustering de uma tabela Delta Lake.
{ ENABLE | DISABLE | INHERIT } PREDICTIVE OPTIMIZATIONAplica-se a:
SQL do Databricks
Databricks Runtime 12.2 LTS e versões posteriores
Somente Catálogo do UnityAltera a tabela Delta Lake gerenciada para a configuração de otimização preditiva desejada.
Por padrão, quando as tabelas são criadas, o comportamento é para
INHERITdo esquema.Quando a otimização preditiva estiver explicitamente habilitada ou herdada como habilitada OPTIMIZE e VACUUM serão automaticamente invocadas na tabela, conforme considerado apropriado pelo Azure Databricks. Para obter mais detalhes, consulte: Otimização preditiva para tabelas gerenciadas do Catálogo do Unity.
-- Enables predictive optimization for my_table > ALTER TABLE my_table ENABLE PREDICTIVE OPTIMIZATION;
Exemplos adicionais
Para ver exemplos de adição de restrições e alteração de colunas do Delta Lake, confira
Artigos relacionados
- ADD CONSTRAINT cláusula: adicionar ou remover restrições de verificação, chaves primárias e chaves estrangeiras.
- ALTER MATERIALIZED VIEW: sintaxe para alterar exibições materializadas.
- ALTER STREAMING TABLE: sintaxe para alterar tabelas de streaming.
- ALTER TABLE Cláusula ... COLUMN: Sintaxe completa para ADD, ALTER, DROP e RENAMECOLUMN.
- ALTER TABLE … PARTITION: sintaxe completa para adicionar, remover e renomear partições.
- Atualizar esquema de tabela: renomear ou alterar tipos de coluna em uma tabela Delta.