+3 votos
620 visitas
Ao realizar o processamento de um XML de integração, o cliente  está informando a data 01/01/0001 mas esta dando erro.

Gostaria de saber qual o comando para pegar a menor data que o banco de dados suporta.
por (62 pontos) | 620 visitas

1 Resposta

+2 votos
Melhor resposta

A menor data suportada pelo ADO.Net é 01/01/1753, para obter esta data pode usar o método MinValue da classe SqlDateTime.

Vale mencionar também que se tentar gravar algum valor menor que a data acima usando o Ado.Net vai causar o erro já conhecido erro de Valor de caractere inválido para especificação de coerção

por (569 pontos)
selecionada por anônimo

Apenas para complementar que, os bancos de dados tem uma forma explícita para definir a "ausência de valor", que é o NULL.

Ou seja, uma coluna do tipo INTEGER no banco, pode estar "sem valor" (NULL) ou pode estar "com o valor zero" (0, zero). São situações diferentes.

Da mesma forma, um campo DATETIME no banco, pode estar "sem valor" (NULL) e também pode estar com a data 01/01/1753, que será um valor válido. Assim como o valor 01/01/0001 também é válido, porém não é gravável através do Ado.Net.

 

Melhores Aug 2025
    200 pontos
    Melhores 2025 Jul 28 - Aug 03
    1. Larson

      156 Pontos

    2. danilo.pereira

      96 Pontos

    3. danilo.pereira

      96 Pontos

    4. danilo.pereira

      96 Pontos

    5. luciano.fronza

      61 Pontos

    6. luciano.fronza

      61 Pontos

    7. luciano.fronza

      61 Pontos

    8. diuari.molinari

      52 Pontos

    9. diuari.molinari

      51 Pontos

    10. diuari.molinari

      51 Pontos

    517 perguntas
    566 respostas
    389 comentários
    704 usuários