Log de auditoria com o Entity Framework 6
![Imagem](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiSoiTCkBUC_3DLYH1_xhFLeGy7rP9HSWBg3xbZuxN1CFJ_sB4RTACEkDBwm7C1R56wVHrc62LYuvnQ3HaDX4StzvR2lckNfjpy2ugzj9KYhv9_omNUmm1FcctSfUp3UTU-A-KiZs_-Nmd_/s400/ef_audit01.png)
Uma das novidades no Entity Framework 6 é a possibilidade de interceptar os comandos SQL que são gerados pela ferramenta de forma bem mais simples que nas versões anteriores. Isso permite, entre outras coisas, efetuar um log de tudo o que é enviado para o banco de dados, facilitando a depuração das aplicações. Mas hoje vou mostrar uma outra coisa bem interessante que podemos fazer ao interceptar o SQL do Entity Framework: log de auditoria. Ou seja, ter a rastreabilidade do que cada usuário fez no sistema, em determinado momento. A ideia central aqui é, para cada atualização de um registro no banco de dados (seja uma inserção, alteração ou exclusão), armazenar essa versão junto do usuário e data e hora de modificação. Vamos olhar a tabela da imagem abaixo, People (à esquerda). Ela possui as colunas Id, FirstName, LastName e Age. Até aí, nada de mais. Agora vamos ver uma outra tabela de mesmo nome, só que criada em um schema diferente (hist). Ela possui as mesmas colunas, com os...