AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / dba / Perguntas / 343541
Accepted
Meera K
Meera K
Asked: 2024-11-12 13:18:16 +0800 CST2024-11-12 13:18:16 +0800 CST 2024-11-12 13:18:16 +0800 CST

Datetime2 no SQL 2014 vs SQL 2022

  • 772

Comportamento do tipo de coluna 'DateTime2' entre SQL 2014 e SQL 2022. Isso foi encontrado quando o cálculo do nosso aplicativo para a diferença de data e hora das colunas do tipo DateTime2 deu errado.

Tentei descobrir no Google se haveria uma configuração específica na propriedade do servidor para colunas do tipo datetime2, mas sem sorte.

Percebido - Melhorias no DateTime2 É declarado que o comportamento é esperado. O Datetime2 com SQL 2014 tem precisão 7 com apenas os primeiros 3 dígitos atualizados, enquanto agora é 7 com SQL 2022 atualizado para todos os 7 dígitos. E então os cálculos com os campos datetime2 estão virando uma bagunça após a atualização.

Agora, há muitas colunas em muitas tabelas que foram definidas como datetime2. Levaria tempo para corrigir todas as consultas, códigos de aplicação.

Haverá alguma solução simples para isso?

sql-server
  • 2 2 respostas
  • 64 Views

2 respostas

  • Voted
  1. Severalnines
    2024-11-19T23:14:45+08:002024-11-19T23:14:45+08:00

    A correção mais simples é converter ou converter DateTime2colunas para uma precisão uniforme como DATETIME2(3)em suas consultas, no entanto, isso é de curto prazo. Você pode usar a função CONVERTor CASTpara imitar funções do SQL Server 2014. Um exemplo:

    SELECT DATEDIFF(MILLISECOND,

    CAST(Column1 AS DATETIME2(3)),

    CAST(Column5 AS DATETIME2(3))) AS DiffMilliseconds

    FROM YourTable;

    Isso garantirá a consistência e evitará alterações no código do aplicativo à medida que você se adapta gradualmente.

    • 1
  2. Best Answer
    Paul White
    2024-11-20T15:54:19+08:002024-11-20T15:54:19+08:00

    Haverá alguma solução simples para isso?

    A única 'solução simples' é executar o banco de dados em um nível de compatibilidade abaixo de 130 até que seu código esteja pronto para as mudanças comportamentais.

    Por exemplo:

    ALTER DATABASE YourDB SET COMPATIBILITY_LEVEL = 120;
    

    Você verá que seu problema desaparecerá.

    Claro, você perderá facilidades disponíveis somente no 130 (e acima). Um resumo está disponível em Diferenças entre o nível de compatibilidade 120 e o nível 130 como ponto de partida.

    Perguntas e respostas relacionadas: Comparação incorreta de datetime e datetime2
    Meu artigo: Não misture com Datetime


    Uma versão anterior da sua pergunta tinha uma demonstração de código. Você estava inserindo em uma datetime2coluna usando select getdate()como fonte — uma função que retorna datetimenot datetime2.

    É aí que a conversão acontece e por isso a situação que descrevo — comparando datetime— é datetime2relevante.

    • 1

relate perguntas

  • SQL Server - Como as páginas de dados são armazenadas ao usar um índice clusterizado

  • Preciso de índices separados para cada tipo de consulta ou um índice de várias colunas funcionará?

  • Quando devo usar uma restrição exclusiva em vez de um índice exclusivo?

  • Quais são as principais causas de deadlocks e podem ser evitadas?

  • Como determinar se um Índice é necessário ou necessário

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    conectar ao servidor PostgreSQL: FATAL: nenhuma entrada pg_hba.conf para o host

    • 12 respostas
  • Marko Smith

    Como fazer a saída do sqlplus aparecer em uma linha?

    • 3 respostas
  • Marko Smith

    Selecione qual tem data máxima ou data mais recente

    • 3 respostas
  • Marko Smith

    Como faço para listar todos os esquemas no PostgreSQL?

    • 4 respostas
  • Marko Smith

    Listar todas as colunas de uma tabela especificada

    • 5 respostas
  • Marko Smith

    Como usar o sqlplus para se conectar a um banco de dados Oracle localizado em outro host sem modificar meu próprio tnsnames.ora

    • 4 respostas
  • Marko Smith

    Como você mysqldump tabela (s) específica (s)?

    • 4 respostas
  • Marko Smith

    Listar os privilégios do banco de dados usando o psql

    • 10 respostas
  • Marko Smith

    Como inserir valores em uma tabela de uma consulta de seleção no PostgreSQL?

    • 4 respostas
  • Marko Smith

    Como faço para listar todos os bancos de dados e tabelas usando o psql?

    • 7 respostas
  • Martin Hope
    Jin conectar ao servidor PostgreSQL: FATAL: nenhuma entrada pg_hba.conf para o host 2014-12-02 02:54:58 +0800 CST
  • Martin Hope
    Stéphane Como faço para listar todos os esquemas no PostgreSQL? 2013-04-16 11:19:16 +0800 CST
  • Martin Hope
    Mike Walsh Por que o log de transações continua crescendo ou fica sem espaço? 2012-12-05 18:11:22 +0800 CST
  • Martin Hope
    Stephane Rolland Listar todas as colunas de uma tabela especificada 2012-08-14 04:44:44 +0800 CST
  • Martin Hope
    haxney O MySQL pode realizar consultas razoavelmente em bilhões de linhas? 2012-07-03 11:36:13 +0800 CST
  • Martin Hope
    qazwsx Como posso monitorar o andamento de uma importação de um arquivo .sql grande? 2012-05-03 08:54:41 +0800 CST
  • Martin Hope
    markdorison Como você mysqldump tabela (s) específica (s)? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Jonas Como posso cronometrar consultas SQL usando psql? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas Como inserir valores em uma tabela de uma consulta de seleção no PostgreSQL? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas Como faço para listar todos os bancos de dados e tabelas usando o psql? 2011-02-18 00:45:49 +0800 CST

Hot tag

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve