Você pode criar e modificar tabelas, restrições, índices e relações no Access escrevendo consultas de definição de dados no SQL exibição. Este artigo explica as consultas de definição de dados e como usá-las para criar tabelas, restrições, índices e relações. Este artigo também pode ajudá-lo a decidir quando usar uma consulta de definição de dados.

Neste artigo

Visão geral

Ao contrário de outras consultas do Access, uma consulta de definição de dados não recupera dados. Em vez disso, uma consulta de definição de dados usa a Linguagem de Definição de Dados para criar, modificar ou excluir objetos de banco de dados.

Observação: A DDL (Linguagem de Definição de Dados) faz parte do linguagem SQL (SQL).

As consultas de definição de dados podem ser muito convenientes. Você pode excluir e re-criar regularmente partes do esquema de banco de dados apenas executando algumas consultas. Considere usar uma consulta de definição de dados se você estiver familiarizado com SQL instruções e planeja excluir e re-criar tabelas, restrições, índices ou relações específicas.

Aviso: Usar consultas de definição de dados para modificar objetos de banco de dados pode ser arriscado, pois as ações não são acompanhadas por caixas de diálogo de confirmação. Se você cometer um erro, poderá perder dados ou alterar inadvertidamente o design de uma tabela. Tenha cuidado ao usar uma consulta de definição de dados para modificar objetos no banco de dados. Se você não for responsável por manter o banco de dados que está usando, consulte o administrador do banco de dados antes de executar uma consulta de definição de dados.

Importante: Faça uma cópia de backup de todas as tabelas envolvidas antes de executar uma consulta de definição de dados.

Palavras-chave DDL

Palavra-chave

Uso

CREATE

Crie um índice ou tabela que ainda não exista.

ALTER

Modificar uma tabela ou coluna existente.

DROP

Exclua uma tabela, coluna ou restrição existente.

ADD

Adicione uma coluna ou uma restrição a uma tabela.

COLUMN

Usar com ADD, ALTER ou DROP

CONSTRAINT

Usar com ADD, ALTER ou DROP

INDEX

Usar com CREATE

TABLE

Use com ALTER, CREATE ou DROP

Início da Página

Criar ou modificar uma tabela

Para criar uma tabela, use um comando CREATE TABLE. Um comando CREATE TABLE tem a seguinte sintaxe:

CREATE TABLE table_name 
(field1 type [(size)] [NOT NULL] [index1]
[, field2 type [(size)] [NOT NULL] [index2]
[, ...][, CONSTRAINT constraint1 [, ...]])

Os únicos elementos necessários de um comando CREATE TABLE são o próprio comando CREATE TABLE e o nome da tabela, mas geralmente você deseja definir alguns campos ou outros aspectos da tabela. Considere este exemplo simples.

Suponha que você queira criar uma tabela para armazenar o nome, o ano e o preço dos carros usados que você está considerando para compra. Você deseja permitir até 30 caracteres para o nome e 4 caracteres para o ano. Para usar uma consulta de definição de dados para criar a tabela, faça o seguinte:

Observação: Você pode primeiro precisar habilitar o conteúdo do banco de dados para que uma consulta de definição de dados seja executado:

  • Na Barra de Mensagens, clique em Habilitar Conteúdo.

Criar uma tabela

  1. Na guia Criar, no grupo Macros & Código, clique em Design de Consulta.

  2. Na guia Design, no grupo Tipo de Consulta, clique em Definição de Dados.

    A grade de design está oculta e a guia SQL objeto view é exibida.

  3. Digite a seguinte instrução SQL:

    CREATE TABLE Cars (Name TEXT(30), Year TEXT(4), Price CURRENCY)

  4. Na guia Design, no grupo Resultados, clique em Executar.

Modificar uma tabela

Para modificar uma tabela, use um comando ALTER TABLE. Você pode usar um comando ALTER TABLE para adicionar, modificar ou soltar (remover) colunas ou restrições. Um comando ALTER TABLE tem a seguinte sintaxe:

ALTER TABLE table_name predicate

onde o predicado pode ser qualquer um dos seguintes:

ADD COLUMN field type[(size)] [NOT NULL] [CONSTRAINT constraint]

ADD CONSTRAINT multifield_constraint

ALTER COLUMN field type[(size)]

DROP COLUMN field

DROP CONSTRAINT constraint

Suponha que você queira adicionar um campo de texto de 10 caracteres para armazenar informações sobre a condição de cada carro. Você pode fazer o seguinte:

  1. Na guia Criar, no grupo Macros & Código, clique em Design de Consulta.

  2. Na guia Design, no grupo Tipo de Consulta, clique em Definição de Dados.

    A grade de design está oculta e a guia SQL objeto view é exibida.

  3. Digite a seguinte instrução SQL:

    ALTER TABLE Cars ADD COLUMN Condition TEXT(10)

  4. Na guia Design, no grupo Resultados, clique em Executar.

Início da Página

Criar um índice

Para criar um índice em uma tabela existente, use um comando CREATE INDEX. Um comando CREATE INDEX tem a seguinte sintaxe:

CREATE [UNIQUE] INDEX index_name
ON table (field1 [DESC][, field2 [DESC], ...])
[WITH {PRIMARY | DISALLOW NULL | IGNORE NULL}]

Os únicos elementos necessários são o comando CREATE INDEX, o nome do índice, o argumento ON, o nome da tabela que contém os campos que você deseja indexar e a lista de campos a serem incluídos no índice.

  • O argumento DESC faz com que o índice seja criado em ordem decrescente, o que pode ser útil se você executar consultas com frequência que procure valores principais para o campo indexado ou que classificar o campo indexado em ordem decrescente. Por padrão, um índice é criado em ordem crescente.

  • O argumento COM PRIMARY estabelece o campo indexado ou os campos como o chave primária da tabela.

  • O argumento WITH DISALLOW NULL faz com que o índice exigir que um valor seja inserido para o campo indexado , ou seja, os valores nulos não são permitidos.

Suponha que você tenha uma tabela chamada Carros com campos que armazenam o nome, ano, preço e condição de carros usados que você está considerando para compra. Suponha também que a tabela tenha se tornado grande e que você inclua frequentemente o campo ano em consultas. Você pode criar um índice no campo Ano para ajudar suas consultas a retornar resultados mais rapidamente usando o seguinte procedimento:

  1. Na guia Criar, no grupo Macros & Código, clique em Design de Consulta.

  2. Na guia Design, no grupo Tipo de Consulta, clique em Definição de Dados.

    A grade de design está oculta e a guia SQL objeto view é exibida.

  3. Digite a seguinte instrução SQL:

    CREATE INDEX YearIndex ON Cars (Year)

  4. Na guia Design, no grupo Resultados, clique em Executar.

Início da Página

Criar uma restrição ou uma relação

Uma restrição estabelece uma condição lógica de que um campo ou combinação de campos deve atender quando os valores são inseridos. Por exemplo, uma restrição UNIQUE impede que o campo restrito aceite um valor que duplicaria um valor existente para o campo.

Uma relação é um tipo de restrição que se refere aos valores de um campo ou combinação de campos em outra tabela para determinar se um valor pode ser inserido no campo restrito ou na combinação de campos. Você não usa uma palavra-chave especial para indicar que uma restrição é uma relação.

Para criar uma restrição, use uma cláusula CONSTRAINT em um comando CREATE TABLE ou ALTER TABLE. Há dois tipos de cláusulas CONSTRAINT: um para criar uma restrição em um único campo e outro para criar uma restrição em vários campos.

Restrições de campo único

Uma cláusula CONSTRAINT de campo único segue imediatamente a definição do campo que restringe e tem a seguinte sintaxe:

CONSTRAINT constraint_name {PRIMARY KEY | UNIQUE | NOT NULL |
REFERENCES foreign_table [(foreign_field)]
[ON UPDATE {CASCADE | SET NULL}]
[ON DELETE {CASCADE | SET NULL}]}

Suponha que você tenha uma tabela chamada Carros com campos que armazenam o nome, ano, preço e condição de carros usados que você está considerando para compra. Suponha também que você frequentemente esqueça de inserir um valor para a condição do carro e que você sempre deseja gravar essas informações. Você pode criar uma restrição no campo Condição que o impeça de deixar o campo vazio usando o seguinte procedimento:

  1. Na guia Criar, no grupo Macros & Código, clique em Design de Consulta.

  2. Na guia Design, no grupo Tipo de Consulta, clique em Definição de Dados.

    A grade de design está oculta e a guia SQL objeto view é exibida.

  3. Digite a seguinte instrução SQL:

    ALTER TABLE Cars ALTER COLUMN Condition TEXT CONSTRAINTRequired NOT NULL

  4. Na guia Design, no grupo Resultados, clique em Executar.

Agora suponha que, depois de um tempo, você perceba que há muitos valores semelhantes no campo Condição que devem ser os mesmos. Por exemplo, alguns dos carros têm um valor Condition de ruim e outros têm um valor ruim.

Observação: Se você quiser seguir junto com os procedimentos restantes, adicione alguns dados falsos à tabela Carros que você criou nas etapas anteriores.

Depois de limpar os valores para que eles sejam mais consistentes, você pode criar uma tabela, chamada CarCondition, com um campo, denominado Condição, que contém todos os valores que você deseja usar para a condição dos carros:

  1. Na guia Criar, no grupo Macros & Código, clique em Design de Consulta.

  2. Na guia Design, no grupo Tipo de Consulta, clique em Definição de Dados.

    A grade de design está oculta e a guia SQL objeto view é exibida.

  3. Digite a seguinte instrução SQL:

    CREATE TABLE CarCondition (Condition TEXT(10))

  4. Na guia Design, no grupo Resultados, clique em Executar.

  5. Crie uma chave primária para a tabela usando uma instrução ALTER TABLE:

    ALTER TABLE CarCondition ALTER COLUMN Condition TEXT CONSTRAINT CarConditionPK PRIMARY KEY

  6. Para inserir os valores do campo Condição da tabela Carros na nova tabela CarCondition, digite o seguinte SQL na guia objeto SQL view:

    INSERT INTO CarCondition SELECT DISTINCT Condition FROM Cars;

    Observação: A SQL nesta etapa é uma consulta acréscimo. Ao contrário de uma consulta de definição de dados, uma consulta de anexação termina com um ponto e vírgula.

  7. Na guia Design, no grupo Resultados, clique em Executar.

Criar uma relação usando uma restrição

Para exigir que qualquer novo valor inserido no campo Condição da tabela Carros corresponde a um valor do campo Condição na tabela CarCondition, você pode criar uma relação entre CarCondition e Carros no campo chamado Condição, usando o seguinte procedimento:

  1. Na guia Criar, no grupo Macros & Código, clique em Design de Consulta.

  2. Na guia Design, no grupo Tipo de Consulta, clique em Definição de Dados.

    A grade de design está oculta e a guia SQL objeto view é exibida.

  3. Digite a seguinte instrução SQL:

    ALTER TABLE Cars ALTER COLUMN Condition CONSTRAINT TEXT FKeyCondition REFERENCES CarCondition (Condition)

  4. Na guia Design, no grupo Resultados, clique em Executar.

Restrições de vários campos

Uma cláusula CONSTRAINT de vários campos só pode ser usada fora de uma cláusula de definição de campo e tem a seguinte sintaxe:

CONSTRAINT constraint_name 
{PRIMARY KEY (pk_field1[, pk_field2[, ...]]) |
UNIQUE (unique1[, unique2[, ...]]) |
NOT NULL (notnull1[, notnull2[, ...]]) |
FOREIGN KEY [NO INDEX] (ref_field1[, ref_field2[, ...]])
REFERENCES foreign_table
[(fk_field1[, fk_field2[, ...]])] |
[ON UPDATE {CASCADE | SET NULL}]
[ON DELETE {CASCADE | SET NULL}]}

Considere outro exemplo que usa a tabela Carros. Suponha que você queira garantir que nenhum dois registros na tabela Carros tenham o mesmo conjunto de valores para Nome, Ano, Condição e Preço. Você pode criar uma restrição UNIQUE que se aplique a esses campos usando o seguinte procedimento:

  1. Na guia Criar, no grupo Macros & Código, clique em Design de Consulta.

  2. Na guia Design, no grupo Tipo de Consulta, clique em Definição de Dados.

    A grade de design está oculta e a guia SQL objeto view é exibida.

  3. Digite a seguinte instrução SQL:

    ALTER TABLE Cars ADD CONSTRAINT NoDupes UNIQUE (nome, ano, condição, preço)

  4. Na guia Design, no grupo Resultados, clique em Executar.

Início da Página

Precisa de mais ajuda?

Expanda suas habilidades
Explore o treinamento
Obtenha novos recursos primeiro
Ingressar no Microsoft Insider

Estas informações foram úteis?

Qual é o seu grau de satisfação com a qualidade da tradução?
O que afetou sua experiência?

Obrigado por seus comentários!

×