O tipo de dados Data/Hora Prolongada armazena informações de data e hora e é semelhante ao tipo de dados Data/Hora, mas fornece um intervalo de datas maior, uma maior precisão fracionária e compatibilidade com o tipo de data datetime2 do SQL Server. Quando importa ou liga dados do Access ao SQL Server, pode mapear consistentemente um campo de Data/Hora Prolongada do Access a uma coluna datetime2 do SQL Server. Para obter mais informações, consulte datetime2 (Transact-SQL).
Aviso Quando criar expressões e utilizar funções data/hora com base no tipo de dados Data/Hora Prolongada no Access poderá perder precisão nos cálculos ou deparar-se com outros problemas com os resultados. Estamos cientes desta questão e planeamos suportar melhor as expressões e funções numa versão futura. Como solução alternativa, pode Criar uma consulta pass-through para utilizar a expressão equivalente do SQL Server e funções de data/hora. Para obter mais informações, consulte Comparação do SQL do Access com o TSQL do SQL Server.
Neste artigo
Comparação dos tipos de dados Data/Hora e Data/Hora Prolongada |
Utilizar o tipo de dados Data/Hora Prolongada como uma cadeia em VBA |
Comparação dos tipos de dados Data/Hora e Data/Hora Prolongada
As seguintes tabelas resumem as diferenças importantes entre os dois tipos de dados.
Atributo |
Data/Hora |
Data/Hora Prolongada |
---|---|---|
Valor Mínimo |
100-01-01 00:00:00 |
0001-01-01 00:00:00 |
Valor Máximo |
9999-12-31 23:59:59,999 |
9999-12-31 23:59:59,9999999 |
Precisão |
0,001 segundos |
1 nanossegundo |
Dimensão |
Ponto flutuante de dupla precisão |
Cadeia codificada de 42 bytes |
Utilizar o tipo de dados Data/Hora Prolongada
As seguintes informações descrevem considerações importantes de utilização.
Vista Estrutura da Tabela Para tirar partido do maior intervalo de dados e maior precisão, pode adicionar um campo a uma tabela do Access. Também pode converter um tipo de dados Data/Hora em Data/Hora Prolongada na vista Estrutura da Tabela. A utilização deste tipo de dados como campo de chave primária também é suportada. Para obter mais informações, consulte Criar uma tabela e adicionar campos.
Introduzir a data e hora A introdução de valores de data e hora é semelhante ao tipo de dados Data/Hora, exceto que também pode introduzir um nanossegundo fracionário. Por exemplo:
-
Formato de entrada: dd/mm/aaaa hh:mm:ss,nnnnnnn
-
Exemplo: 15/06/1215 09:25:3,234
Se existirem mais de 7 nanossegundos fracionários, são arredondados para 7 dígitos. Para controlar a visualização dos nanossegundos fracionários, abra a Tabela, no friso selecione Campos e, no grupo Formatação, selecione Aumentar Casas Decimais ou Diminuir Casas Decimais .
Formatação Ambos os tipos de dados Data/Hora e Data/Hora Prolongada utilizam cadeias de formatação padrão semelhantes: Data Geral, Data por Extenso, Data Normal, Data Abreviada, Hora Completa, Hora Normal e Hora Abreviada e ambos suportam formatação personalizada. Para o tipo de dados Data/Hora Prolongada, os formatos padrão baseados no tempo também suportam precisão fracionária para nanossegundos. O tipo de dados Data/Hora Prolongada tem a predefinição de formato Data Geral e Hora Completa e segue as opções especificadas nas definições regionais do Windows. Também pode controlar a formatação da precisão fracionária através da propriedade Casas Decimais para especificar o número de dígitos à direita da vírgula (1-7).
Ligar e importar Também pode ligar ou importar a partir de bases de dados com um tipo de dados correspondente, como o tipo de dados datetime2 do SQL Server. São suportadas as bases de dados da versão de 2014 ou posteriores do SQL Server. O tipo de dados Data/Hora Prolongada necessita da utilização do Microsoft ODBC Driver para SQL Server 11 ou posterior. Recomendamos a utilização do Microsoft ODBC Driver para SQL Server 13.1. A utilização do OLE DB também é suportada. Para obter mais informações, consulte Data Type Support for ODBC Date and Time Improvements (Suporte de Tipo de Dados para Data e Hora Melhoradas em ODBC) e Use Enhanced Date and Time Features (OLE DB) (Utilizar Funcionalidades de Data e Hora Melhoradas [OLE DB]).
Formulários e relatórios Pode adicionar o tipo de dados Data/Hora Prolongada a um formulário ou relatório. Num formulário, pode utilizar o seletor de datas e a máscara de introdução para introduzir uma data com um intervalo maior, mas não a precisão fracionária para nanossegundos.
Suporte de Expressões O tipo de dados Data/Hora Prolongada suporta Funções de Agregação do SQL e avaliação de expressões. Por exemplo, utilizar LoggedDateTime como um campo com o tipo de dados Data/Hora Prolongada:
Tarefa |
Exemplo |
Resultado |
---|---|---|
Encontrar o valor mínimo |
Min(LoggedDateTime) |
A data e hora mais cedo dentro do intervalo |
Extrair o mês |
Month(LoggedDateTime) |
O nome do mês, por exemplo, janeiro |
Adicionar um dia |
[LoggedDateTime]+1 |
Terça-feira tornar-se-ia quarta-feira |
Considerações de Retrocompatibilidade
O tipo de dados Data/Hora Prolongada não é compatível com as versões anteriores do Microsoft Access. Se o tipo for utilizado numa tabela local do Access, as versões do Access que não incluam a funcionalidade não conseguirão abrir a base de dados.
Pode ativar ou desativar o tipo de dados Data/Hora Prolongada para ligar e importar operações com a opção De Suporte data/Hora de Extensão de Dados da Opção de Acesso à Base de Dados Atualpara Tabelas Ligadas/Lmported. Para obter mais informações, consulte Definir opções do utilizador para a base de dados atual.
Utilizar o tipo de dados Data/Hora Prolongada como uma cadeia em VBA
Os exemplos de VBA que se seguem utilizam métodos DAO para visualizar, introduzir e avaliar o tipo de dados Data/Hora Prolongada com base na tabela abaixo.
ID |
DTEData |
DTData |
1 |
1/1/2 1:01:03,1234567 |
1/1/2001 |
Nome da tabela DTETable
Tipo de dados de ID: Numeração automática Tipo de dados DTEData: Data/Hora Prolongada Tipo de dados DTData: Data/HoraExemplo: Mostrar a data e hora
O exemplo a seguir mostra a data e a hora. O formato utilizado é dd/mm/aaaa hh:mm:ss,nnnnnnn em relógio de 24 horas. O formato não é personalizável.
Dim db As Database
Dim rs As Recordset
Set db = CurrentDb
Set rs = db.OpenRecordset("DTETable")
Do Until rs.EOF
Debug.Print rs!DTETable
rs.MoveNext
Loop
Resultado O Access apresenta: 01/01/0002 01:01:03,1234567.
Exemplo: Introduzir a data e hora
O exemplo seguinte introduz a data e a hora com um formato de cadeia. Todos os formatos padrão de data e hora são suportados.
Dim db As Database
Dim rs As Recordset
Set db = CurrentDb
Set rs = db.OpenRecordset("DTETable")
With CurrentDb.OpenRecordset("DTETable")
.AddNew
![DTEData] = "1/1/9999 1:1:1.0123 AM"
![DTData] = #1/1/2001#
.Update
End With
Resultado O Access adiciona uma nova linha (ID = 2):
ID |
DTEData |
DTData |
1 |
1/1/2 1:01:03,1234567 |
1/1/2001 |
2 |
1/1/9999 1:01:01,0123000 |
1/1/2001 |
Exemplo: Avaliar uma expressão de consulta
O exemplo seguinte utiliza a Função Dia para extrair o número do dia dos campos de data e hora.
Dim db As Database
Dim rs As Recordset
Set db = CurrentDb
Set rs = db.OpenRecordset("SELECT Day(DTEData) as day FROM DTETable")
Do Until rs.EOF
Debug.Print "The day of the month is: "&rs!day
rs.MoveNext
Loop
Resultado O Access apresenta:
O dia do mês é: 1
O dia do mês é: 1Consulte Também
Introdução aos tipos de dados e propriedades de campo