Compatibilidade da FileTable com outros recursos do SQL Server
Aplica-se a: SQL Server
Descreve como as FileTables funcionam com outros recursos do SQL Server.
Grupos de disponibilidade Always On e FileTables
Quando o banco de dados que contém dados FILESTREAM ou FileTable pertence a um grupo de disponibilidade AlwaysOn:
A funcionalidade FileTable é parcialmente compatível com grupos de disponibilidade Always On. Depois de um failover, os dados de FileTable estarão acessíveis na réplica primária, mas os dados de FileTable não estarão acessíveis em réplicas secundárias legíveis.
Observação
Depois de um failover, toda a funcionalidade do FILESTREAM tem suporte. Os dados de FILESTREAM podem ser acessados em ambas as réplicas secundárias legíveis e no novo primário.
As funções FILESTREAM e FileTable aceitam ou retornam VNNs (nomes de rede virtual) em vez de nomes de computadores. veja mais informações sobre essas funções em FILESTREAM e FileTable (Transact-SQL).
Todo o acesso aos dados FILESTREAM ou FileTable pelas APIs do sistema de arquivos deve usar VNNs em vez de nomes de computadores. Veja mais informações em usar FILESTREAM e FileTable com grupos de disponibilidade Always On.
Partição e FileTables
O particionamento não é compatível com FileTables. Com o suporte para vários grupos de arquivos FILESTREAM, problemas simples de expansão podem ser resolvidos sem o uso do recurso de particionamento na maioria dos cenários (ao contrário de FILESTREAMs do SQL 2008).
Replicação e FileTables
Não há suporte para replicação de recursos relacionados (inclusive replicação transacional, replicação de mesclagem, captura de dados de alterações e controle de alterações) com FileTables.
Semântica de transação e FileTables
Aplicativos do Windows
Os aplicativos do Windows não entendem transações de banco de dados; então as operações de gravação do Windows não fornecem as propriedades ACID de uma transação de banco de dados. Portanto, as reversões e a recuperação transacionais não são possíveis com operações de atualização do Windows.
Aplicativos Transact-SQL
Para os aplicativos Transact-SQL que funcionam na coluna FILESTREAM (file_stream) em uma FileTable, as semânticas de isolamento são iguais às do tipo de dados FILESTREAM em uma tabela de usuário normal.
Notificações de consulta e FileTables
A consulta não pode conter referência à coluna FILESTREAM na FileTable, na cláusula WHERE ou em qualquer outra parte da consulta.
SELECT INTO e FileTables
As instruções SELECT INTO de uma FileTable não propagam a semântica da FileTable na tabela de destino criada (da mesma forma que as colunas FILESTREAM em uma tabela normal). Todas as colunas da tabela de destino se comportam como colunas normais. Elas não têm nenhuma semântica de FileTable associada.
Gatilhos e FileTables
Gatilhos DDL (linguagem de definição de dados)
Não há nenhuma consideração especial para gatilhos DDL com FileTables. Gatilhos DDL normais acionam as operações Create/Alter database, além das operações CREATE/ALTER TABLE para FileTables. Os gatilhos podem recuperar os dados de eventos reais, que incluem o texto do comando DDL e outras informações por meio da chamada da função EVENTDATA(). Não há nenhum novo evento ou alteração do esquema Eventdata existente.
Gatilhos DML (linguagem de manipulação de dados)
Estas restrições são impostas durante a operação DDL para criar gatilhos.
As FileTables não oferecem suporte a gatilhos INSTEAD OF para operações DML. Essa é uma restrição existente em todas as tabelas que contêm colunas FILESTREAM.
As FileTables oferecem suporte a gatilhos AFTER para operações DML.
Os gatilhos definidos em uma FileTable não podem atualizar FileTables (inclusive a FileTable pai). Essa restrição existe principalmente para impedir que um gatilho entre em conflitos de bloqueio com bloqueios mantidos pelo acesso ao sistema de arquivos na mesma transação.
Acesso não transacional e seus efeitos em gatilhos
Quando o acesso de atualização não transacional é permitido em um banco de dados, é possível fazer uma atualização in loco dos dados FILESTREAM em qualquer tabela, inclusive FileTable, nesse banco de dados. Devido a essa possibilidade, a imagem anterior do conteúdo FILESTREAM talvez não esteja disponível para ser usada pelo gatilho.
Para operações de atualização não transacionais através do sistema de arquivos, o SQL Server cria uma transação interna para capturar a operação CloseHandle, e qualquer gatilho DML definido pode ser disparado como parte dessa transação. Uma reversão, como uma transação dentro do corpo do gatilho, embora não esteja impedida, não reverte as alterações feitas no FILESTREAM. Tal reversão também pode impedir o disparo de gatilhos Update, mesmo que o conteúdo FILESTREAM possa ter sido alterado.
Além desses impactos, os gatilhos em FileTables precisam lidar com alguns comportamentos adicionais
Com operações de atualização não transacionais em uma FileTable através do sistema de arquivos, é possível que o conteúdo FILESTREAM seja bloqueado exclusivamente por outras operações Win32 e não estejam acessíveis para leitura/gravação por meio do corpo do gatilho. Nesses casos, qualquer tentativa de acessar o conteúdo FILESTREAM dentro do corpo do gatilho pode resultar em um erro de "Violação de Compartilhamento". Os gatilhos devem ser criados para tratar esses erros de maneira adequada.
A imagem AFTER do FILESTREAM pode não ser estável porque, na maioria dos casos, pode estar sendo ativamente gravada por outras atualizações não transacionais ao mesmo tempo (devido aos modos de compartilhamento permitidos no acesso ao sistema de arquivos).
O encerramento anormal de identificadores Win32, como a eliminação explícita de identificadores Win32 por um administrador OU uma pane do banco de dados, não executa gatilhos de usuário durante as operações de recuperação, embora o conteúdo FILESTREAM possa ter sido alterado pelo aplicativo Win32 encerrado de forma anormal.
Exibições e FileTables
Exibições
Uma exibição pode ser criada em um FileTable como em qualquer outra tabela. Entretanto, as considerações a seguir se aplicam a uma exibição criada em uma FileTable:
As exibições não têm nenhuma semântica de FileTable. Isso é, as colunas na exibição (inclusive as colunas de atributos de arquivo) se comportam da mesma forma que as colunas de exibição normais, sem qualquer semântica especial, e o mesmo acontece para as linhas que representam Arquivos/diretórios.
As exibições podem ser atualizadas com base na semântica de "exibição atualizável", mas as restrições de tabela subjacentes podem rejeitar as atualizações, como na tabela.
Você pode visualizar o caminho de um arquivo na exibição adicionando-o como uma coluna explícita na exibição. Por exemplo:
CREATE VIEW MP3FILES AS SELECT column1, column2, ..., GetFileNamespacePath() AS PATH, column3,... FROM Documents
Exibições indexadas
Atualmente, as exibições indexadas não podem incluir colunas FILESTREAM ou colunas computadas/computadas persistentes que dependem das colunas FILESTREAM. Esse comportamento permanece inalterado com as exibições também definidas na FileTable.
Isolamento de instantâneo e FileTables
O RCSI (isolamento de instantâneo de leitura confirmada) e o SI (isolamento de instantâneo) dependem da capacidade de ter um instantâneo dos dados disponível para leitores quando operações de atualização estão ocorrendo nos dados. Entretanto, as FileTables permitem o acesso de gravação não transacional aos dados do fluxo de dados. Como resultado, as restrições a seguir se aplicam a esses recursos em bancos de dados que contêm FileTables:
Um banco de dados que contém FileTables pode ser alterado para habilitar o RCSI/SI.
Quando o acesso não transacional está definido como FULL para o banco de dados, uma transação sendo executada no RCSI ou SI tem o seguinte comportamento:
Qualquer leitura do Transact-SQL da coluna file_stream de FileTable falharia. INSERT e UPDATE para a coluna teriam êxito, contanto que não lessem a partir da coluna file_stream.
Se a instrução Transact-SQL especificar dicas da tabela READCOMMITTEDLOCK, as leituras terão êxito, e aplicarão bloqueios nas linhas, em vez de usar o controle de versão de linha.
As solicitações abertas de FileStream Win32 transacionado também falhariam.
O acesso não transacionado Win32 a FileTable terá êxito. Todas as consultas internas feitas pela FileTable não são afetadas.
A indexação de texto completo sempre terá êxito, não importa quais sejam as opções de banco de dados (READ_COMMITTED_SNAPSHOT ou ALLOW_SNAPSHOT_ISOLATION).
Bancos de dados secundários legíveis
As mesmas considerações se aplicam a bancos de dados secundários legíveis sobre instantâneos, como descrito na seção acima, Isolamento de instantâneo e FileTables.
Bancos de dados independentes e FileTables
O recurso FILESTREAM do qual o recurso FileTable depende exige alguma configuração fora do banco de dados. Portanto, um banco de dados que usa FILESTREAM ou FileTable não é contido completamente.
Você poderá definir a retenção de banco de dados como PARTIAL se desejar usar determinados recursos de bancos de dados contidos, como usuários contidos. Neste caso, no entanto, algumas das configurações de banco de dados não estão contidas no banco de dados e não são movidas automaticamente quando o banco de dados é movido.