Define uma nova tabela ou um novo arquivo do tipo tabela e sua estrutura (campos).
Sintaxe
DBCreate( < cName >, < aStruct >, [ cDriver ] )
Parâmetros
Nome | Tipo | Descrição | Obrigatório | Referência |
---|---|---|---|---|
cName | caractere | Indica o nome da tabela que será criada. Dependendo da RDD utilizada é possível informar a pasta onde a tabela será criada que por padrão é a pasta inicial do ambiente configurado (StartPath). | X |
|
aStruct | vetor | Indica o array que contém as informações dos campos que serão utilizados para criar a tabela. | X |
|
cDriver | caractere | Indica a RDD (Replaceable Database Driver) que será utilizada para criar a tabela que por padrão é o driver de que gerencia tabelas locais (localFiles). |
|
|
Observações
A seguir, observe a relação de erros mais comuns:
Mensagem | Descrição | Tipo |
---|---|---|
DBCreate - Database files can only be created on the server | O nome do arquivo não pode conter a unidade de disco, pois, por convenção, o mesmo seria criado na máquina onde o cliente remoto está sendo executado. | Erro Fatal |
DBCreate - Invalid empty filename | O nome do arquivo não foi especificado. | Erro |
DBCreate - Fields name cannot be 'DATA' | DATA é uma palavra reservada e seu uso não é suportado por aquela RDD ou por aquele SGBD. | Erro |
DBCreate - The length of fields name must be at most 10 | O nome do campo não pode ter mais de 10 caracteres. | Erro |
DBCreate - Fields name must be defined | O nome do campo não foi definido. | Erro |
DBCreate - Fields type is not defined | O tipo do campo não foi definido. | Erro |
DBCreate - Invalid fileds type | O tipo do campo é diferente de 'C', 'D', 'L', 'M' e 'N'. | Erro |
DBCreate - Invalid numeric field format | O formato para campo numérico utilizado é inválido.
| Erro |
Warning - DBCreate - field name will be truncated to 10 characters | O nome do campo possui mais de 10 caracteres e somente os 10 primeiros caracteres serão considerados. | Warning |
DBCreate - Warning - Fields order has changed in file: Memo fields must be in the end of table in Ctree or Btrieve driver | A ordem dos campos foi alterada, os campos do tipo Memo foram movidos para o final da tabela. | Warning |
As mensagens do tipo Erro encerram o programa com uma ocorrência de erro recuperável (possível de ser recuperada usando ErrorBlock ou SysErrorBlock). As mensagens do tipo Erro Fatal encerram o programa com uma ocorrência de erro não recuperável. As mensagens do tipo Warning não encerram o programa.
Importante
Para obter mais informações sobre erros decorrentes de permissões e direitos na pasta em que se está tentando criar o arquivo ou por algum problema no banco de dados, consulte as mensagens do servidor de aplicação e do banco de dados.
As mensagens de erro retornadas por esta função podem conter detalhes específicos da RDD em uso, estes detalhes são importantes para um diagnóstico adequado em caso de não-conformidade ao executar a instrução.
Independente da causa, uma falha na criação da tabela gera uma ocorrência crítica de erro AdvPL, que interrompe o programa/aplicação.
RDDs que podem ser utilizados:
- CTREECDX: c-tree
- DBFCDX: RDD indicada no arquivo de configuração do servidor de aplicação através da chave LocalFiles.
- DBFCDXADS: ADS Local
- DBFCDXAX: ADS Server
- DBFCDXTTS: mantido por compatibilidade e possui o mesmo comportamento do RDD DBFCDX, utilize o RDD DBFCDX.
- TOPCONN: RDD para uso com bancos de dados relacionais.
- SQLITE_SYS: RDD para uso com banco de dados SQLite, com persistência de tabelas, mesmo depois de fechar a conexão (disponível a partir do Protheus 12).
- SQLITE_TMP: RDD para uso com banco de dados SQLite, com tabelas em disco, removidas automaticamente ao final da conexão (disponível a partir do Protheus 12).
- SQLITE_MEM: RDD para uso com banco de dados SQLite, com tabelas em memória, liberadas automaticamente ao final da conexão (disponível a partir do Protheus 12).
Limites
Cada RDD tem diferenciados limites com relação:
- Quantidade de campos.
- Tamanho máximo de header (soma dos tamanhos dos campos na estrutura).
- Precisão numérica máxima, onde alguns dos limites estão implícitos na linguagem, outros implícitos na RDD e outros implícitos no SGBD utilizado.
Limites convencionados para o desenvolvimento de aplicações portáveis em AdvPL
Uma das características do AdvPL mais importante, e enfatizada no desenvolvimento de aplicações, é a portabilidade da solução para diferentes ambientes, plataformas e SGBDs com alterações mínimas no código-fonte AdvPL. Para procurar manter estas premissas no desenvolvimento de uma solução, é prudente respeitar alguns limites no desenvolvimento de aplicações.
As definições de uma tabela de dados envolvem o número de colunas da tabela, tamanho do registro (a soma do tamanho de todas as colunas), tamanhos máximos para cada campo, bem como as definções de índices da tabela, e para cada uma destas definições, existe um limite. Os limites abaixo convencionados são contemplados por todas as RDDs implementadas:
Limites convencionados | Limite |
---|---|
Número de campos por tabela | <= 256 |
Tamanho do registro | <= 7000 Bytes |
Quantidade de índices por tabela | <= 15 |
Quantidade de campos por chave de índice | <= 14 |
Tamanho do registro da expressão de índice | <= 140 Bytes (*) |
Tamanho máximo de um campo "C" (Caractere) | <= 254 Bytes |
Tamanho máximo de um campo "M" (Memo) | <= 64 KB (**) |
(*) O limite de 140 bytes para registro de expressão de índice foi convencionado devido à limitação do driver ADS (Local e/ou Server), onde a criação de uma expressão de índice com chave maior que 140 bytes pode ocasionar ocorrência de erro ADS 7022 - Maximum index levels exceeded, após suscessivas inclusões de registros na tabela.
(**) Com o uso da RDD TOPCONN, mediante parametrização específica no TOTVS Application Server (Servidor de Aplicação), é possível expandir o limite de armazenamento e recuperação de dados de campos "M" (Memo) para até 1 MB.
Mensagens de advertência
A tabela criada respeita a ordem dos campos especificado no array de parâmetro contendo a estrutura, exceto quando um ou mais campos do tipo "M" (MEMO) sejam especificados na estrutura, e os campos MEMO não sejam os últimos campos do array de estruturas, e a RDD utilizada for "CTREECDX" ou "DBFCDX" com o ambiente configurado para usar c-tree (Local e/ou Server) para controle de tabelas locais. Neste caso, a função emite uma mensagem de advertência e automaticamente coloca todos os campos do tipo "M" no final da estrutura definida.
Exemplos
#INCLUDE "TOTVS.CH" User Function Exemplo() Local aEstrutura := { ; { 'Cod' , 'N', 3, 0 }, ; { 'Nome' , 'C', 10, 0 }, ; { 'Idade', 'N', 3, 0 }, ; { 'Nasc' , 'D', 8, 0 }, ; { 'Pagto', 'N', 7, 2 } ; } // Cria a tabela com a RDD corrente DBCREATE( '\teste\tst.dbf', aEstrutura ) USE '\teste\tst.dbf' VIA 'DBFCDX' NEW Return