Como controlar dados com sql: 2011 tabelas bitemporais
Video: Curso de SQL
Conteúdo
Às vezes você quer saber tanto quando ocorreu um evento no mundo real e quando o evento foi gravado no banco de dados SQL. Para casos como este, você pode usar uma tabela que é uma tabela de versão do sistema e uma tabela de período de tempo de aplicação. Essas tabelas são conhecidos como mesas bitemporais.
Video: comandos SQL.avi
Há uma série de casos em que uma tabela bitemporal pode ser chamado para. Suponha, por exemplo, que um dos seus funcionários move sua residência em toda a linha de estado de Oregon a Washington. Você deve ter em conta o fato de que seu estado de retenção de imposto de renda deve mudar a partir da data oficial do movimento.
No entanto, é improvável que a mudança para o banco de dados será feita exatamente no mesmo dia. Ambas as vezes precisa ser registrado, e uma mesa de bitemporal pode fazer essa gravação muito bem. Os registros de controle de versão do sistema O período de tempo quando a mudança se tornou conhecido ao banco de dados, e os registros de período de tempo de aplicação quando o movimento legalmente entrou em vigor. Aqui está um código de exemplo para criar tal tabela:
Video: Crud Básico em Windows Forms, com C# e SQL Server - Parte 1
CRIAR employee_bt TABELA (EmpID INTEIRO, EmpStart DATA, EmpEnd DATA, EmpDept IntegerPERIOD PARA EmpPeriod (EmpStart, EmpEnd), Sys_Start TIMESTAMP (12) GERADO ALWAYSAS linha inicial, Sys_End TIMESTAMP (12) GERADA POR FIM ALWAYSAS FILEIRA, EmpName VARCHAR (30), EmpStreet VARCHAR (40), EmpCity VARCHAR (30), EmpStateProv VARCHAR (2), EmpPostalCode VARCHAR (10), o prazo de SYSTEM_TIME (Sys_Start, Sys_End), CHAVE PRIMÁRIA (EmpID, EPeriod SEM sobreposições), EXTERNA CHAVE (EDept, PERÍODO EPeriod) Referências Dept (DEPTID, PERÍODO dperiod)) com o sistema VERSIONING-
mesas bitemporais servir aos propósitos de ambas as tabelas de versão do sistema e tabelas de tempo de aplicação. O utilizador fornece valores para o período de início e fim colunas de tempo de aplicação. A INSERIR operação em tal tabela define automaticamente o valor do período de sistema em tempo para a hora da transação. O valor da coluna final do período de tempo de sistema é automaticamente ajustada para o valor mais alto permitida para o tipo de dados dessa coluna.
ATUALIZAR e EXCLUIR operações funcionam como fazem para tabelas de período de tempo de aplicação padrão. Como acontece com as tabelas de versão do sistema, ATUALIZAR e EXCLUIR operações afetam apenas linhas atuais, e com cada tal operação uma linha histórica é automaticamente inserido.
Uma consulta feita em cima de uma mesa bitemporal pode especificar um período de tempo de aplicação, um período de versão do sistema, ou ambos. Aqui está um exemplo do caso “ambos”:
Video: 11_Vídeo Aula: Classe JAVA(Inserir, excluir, atualizar e consultar Banco de Dados)
employee_bt EmpIDFROM SELECT FOR TEMPO sistema como OFTIMESTAMP `2013/07/15 00: 00: 00`WHERE EmpID = 314159 ANDEmpPeriod contém a data` 2013/06/20 00: 00: 00`-