quarta-feira, 10 de outubro de 2012

Tipos de Campos no MySQL, saiba como escolher o tipo correto



Tipos de Campos no MySQL, saiba como escolher o tipo correto


(Este post foi publicado por www.rcoli.com.br, ver fonte)

Este post tem o objetivo de ajudar o desenvolvedor na escolha adequada do tipo de campo que deverá utilizar no banco MySQL para persistir seus dados.
O desenvolvedor inexperiente costuma confundir bastante os tipos de campo da linguagem utilizada (PHP por exemplo) com os tipos que o banco pode armazenar. Um exemplo clássico dessa confusão é o booleano que é automaticamente convertido de true para 1 e false para 0 (zero).  Além disso, há o clássico erro de armazenamento de CPF em campo numérico o que faz com que todos os zeros a esquerda se percam.
Portanto coloco abaixo a tabela com os campos do MySQL para que sirva de um guia de implementação do banco de dados de sua aplicação.
Lembro ainda que antes de mais nada você deve identificar qual o tipo de variável que irá armazenar: número, texto, binário, data,  lista ou combinação destes. Em seguida estimar o tamanho do campo e se será variável ou fixo. O MySQL costuma preencher campos texto não variáveis com espaços em branco. Em seguida, verificar se permitirá nulo ou não, se é uma chave candidata, primária, estrangeira, índice ou único.
Não há uma regra fixa para saber como os bancos deverão ser implementados, mas tenha sempre em mente que neste caso, mais é melhor. Ou seja, é melhor sobrar espaço do que ter uma informação inserida com pedaços faltando. Já viu alguém nascer no “Rio de Jane” pois o desenvolvedor não colocou o campo com o tamanho correto?!
Observações:
  • O tamanho do campo para tipos numéricos não afeta o intervalo de valores que pode ser armazenado na coluna. Colunas definidas como TINYINT (1) ou TINYINT (20) podem armazenar exatamente, os mesmos valores. Em vez disso, para inteiros, o tamanho determina a largura do campo, para casas decimais, o tamanho é o número total de dígitos que pode ser armazenado.
  • Muitos dos tipos de dados têm nomes sinônimos: INT e INTEGER, DEC e DECIMAL, etc
  • O tipo de campo TIMESTAMP é automaticamente definido com a data e hora quando um INSERT ou UPDATE ocorre, mesmo se nenhum valor for especificado para esse campo . Se uma tabela possui múltiplas colunas TIMESTAMP, somente a primeira será atualizada quando um INSERT ou UPDATE é realizado.
  • MySQL também tem diversas variantes para os tipos de texto que permitem o armazenamento de dados binários. Estes tipos são BINARY, VARBINARY, TINYBLOB, MEDIUMBLOB, e LONGBLOB. Esses tipos são usados para armazenamento de arquivos ou dados criptografados.
Tipos Numéricos
TipoUsoTamanho
AtributoMINMAX
TINYINTUm inteiro muito pequenoSigned:-128127
Unsigned0255
SMALLINTUm inteiro pequenoSigned:–3276832767
Unsigned065535
MEDIUMINTUm inteiro de tamanho medianoSigned:–83886088388607
Unsigned016777215
INT or INTEGERUm inteiro de tamanho normalSigned:–21474836482147483647
Unsigned04294967295
BIGINTUm inteiro de temanho grandeSigned:–92233720368547758089223372036854775807
Unsigned018446744073709551615
FLOATUm pequeno número de ponto flutuante (precisão simples)Signed–3.402823466E+38–1.175494351E-38, 0
1.175494351E-383.402823466E+38
Não pode ser unsigned-
OBSSe o número de decimais não for especificado ou for <= 24 será de precisão simples
DOUBLE,
DOUBLE PRECISION,
REAL
Um número de ponto flutuante de tamanho normal (precisão dupla)Signed-1.7976931348623157E+308-2.2250738585072014E-308, 0
2.2250738585072014E-3081.7976931348623157E+308
Não pode ser unsigned-
OBSSe o número de decimais não for especificado ou for 25 <= Decimals <= 53 será de precisão dupla
DECIMAL,
NUMERIC
Um número de ponto flutuante descompactado .SignedSe comporta como um campo CHAR: “descompactado” significa que o número é armazenado como uma string, usando um caractere para cada dígito do valor. O ponto decimal e, para números negativos, o sinal ‘-’ não é contado. Se o decimal for 0, os valores não terão ponto decimal ou parte fracionária.O alcance máximo de valores decimais é o mesmo que para o DOUBLE, mas a faixa atual para um campo DECIMAL dado pode ser limitado pela escolha de comprimento e decimais.
Não pode ser unsigned-
OBSSe Decimais é deixado de fora ele é definido como 0. Se o comprimento é deixado de fora ele é definido como 10. Note que no MySQL 3,22 o comprimento inclui o sinal eo ponto decimal
Campos de Datas
FormatoMINMAX
DATEData‘1000-01-01’‘9999-12-31’
OBSFormato: ‘YYYY-MM-DD’
DATETIMEData e horário‘1000-01-01 00:00:00’‘9999-12-31 23:59:59’
OBSFormato: ‘YYYY-MM-DD HH:MM:SS’
TIMESTAMPTimestamp‘1970-01-01 00:00:00’aproximadamente 2037
OBSFormato: YYYYMMDDHHMMSS, YYMMDDHHMMSS, YYYYMMDD ou YYMMDD, dependendo se M é 14 (ausente), 12, 8 ou 6, podendo ser strings ou números.
Este tipo é recomendável para instruções de INSERT ou UPDATE pois é automaticamente marcado com os valores da operação mais recente quando não informado.
TIMEA time‘-838:59:59’‘838:59:59’
OBSformato: ‘HH:MM:SS’, podem ser strings ou números
YEARAnos com 2 ou 4 digitos. O padrão é 4 digitos4 digitos19012155 e 0000
2 digitos19702069
OBSFormato: YYYY
podem ser strings ou números.
Campos Texto
MINMAX
CHARString de tamanho fixo. Sempre é completada com espaços a direita até o tamanho definido1255 caracteres
OBSEspaços excessivos são removidos quando o valor é trazido.Os valores são ordenados e comparados ignorando caixas altas e baixas de acordo com a codificação padrão, a menos que seja fornecido uma chave binária.
VARCHARString de tamanho variável1255 caracteres
OBSOs valores são ordenados e comparados ignorando caixas altas e baixas de acordo com a codificação padrão, a menos que seja fornecido uma chave binária.Nota: Espaços execessivos são removidos quando o valor é inserido.
TINYTEXT0255 (2^8 – 1) caracteres
TEXT065535 (2^16 – 1) caracteres
MEDIUMTEXT016777215 (2^24 – 1) caracteres
LONGTEXT04294967295 (2^32 – 1) caracteres
Dados Binários
TINYBLOB0255 (2^8 – 1) caracteres
BLOB065535 (2^16 – 1) caracteres
MEDIUMBLOB016777215 (2^24 – 1) caracteres
LONGBLOB04294967295 (2^32 – 1) caracteres
Listas
MINMAX
ENUMEnumeraçãoString que pode conter apenas um valor ou zero65535 valores distintos.
SETListaString que pode conter zero ou mais valores64 itens


Fonte extraída de www.rcoli.com.br e o mesmo postou as suas fontes : 


Nenhum comentário:

Postar um comentário