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 / 44557
Accepted
swasheck
swasheck
Asked: 2013-06-15 10:40:27 +0800 CST2013-06-15 10:40:27 +0800 CST 2013-06-15 10:40:27 +0800 CST

Como essas configurações de nível de isolamento de instantâneo interagem em uma instância do SQL Server 2005?

  • 772

Comecei a solucionar um tempdbproblema que estamos tendo no SQL Server 2005 Enterprise Edition. Um desenvolvedor está recebendo um erro tempdbde falta de espaço. Tecnicamente, o erro é:

A transação foi interrompida ao acessar a linha com versão na tabela 'dbo.inserted' no banco de dados 'dbname'. A linha com versão solicitada não foi encontrada. Seu tempdb provavelmente está sem espaço. Consulte BOL sobre como configurar o tempdb para controle de versão

Eu olhei para a configuração do banco de dados sys.databasese encontrei as seguintes configurações:

snapshot_isolation_state: 0

snapshot_isolation_state_desc: OFF

is_read_committed_snapshot_on: 1

Pesquisei o que isso significava no BOL e as informações importantes são as seguintes:

snapshot_isolation_state

Estado das transações de isolamento de instantâneo permitidas, conforme definido pela opção ALLOW_SNAPSHOT_ISOLATION:

0 = O estado de isolamento do instantâneo está DESLIGADO (padrão). O isolamento de instantâneo não é permitido.

1 = Estado de isolamento de instantâneo LIGADO. O isolamento de instantâneo é permitido.

2 = O estado de isolamento do instantâneo está em transição para o estado DESLIGADO. Todas as transações têm suas modificações versionadas. Não é possível iniciar novas transações usando isolamento de instantâneo. O banco de dados permanece na transição para o estado OFF até que todas as transações que estavam ativas quando ALTER DATABASE foi executado possam ser concluídas.

3 = O estado de isolamento do instantâneo está em transição para o estado ON. Novas transações têm suas modificações versionadas. As transações não podem usar isolamento de instantâneo até que o estado de isolamento de instantâneo se torne 1 (ON). O banco de dados permanece na transição para o estado ON até que todas as transações de atualização que estavam ativas quando ALTER DATABASE foi executado possam ser concluídas.

snapshot_isolation_state_desc

Descrição do estado das transações de isolamento de instantâneo permitidas, conforme definido pela opção ALLOW_SNAPSHOT_ISOLATION:

  • DESLIGADO
  • SOBRE
  • IN_TRANSITION_TO_ON
  • IN_TRANSITION_TO_OFF

is_read_committed_snapshot_on

1 = A opção READ_COMMITTED_SNAPSHOT está ATIVADA. As operações de leitura no nível de isolamento de confirmação de leitura são baseadas em varreduras de instantâneo e não adquirem bloqueios.

0 = a opção READ_COMMITTED_SNAPSHOT está DESLIGADA (padrão). As operações de leitura no nível de isolamento de confirmação de leitura usam bloqueios de compartilhamento.

Se estou entendendo isso corretamente, snapshot_isolation_stateestá DESLIGADO e não permitido. No entanto, o 1 is_read_committed_snapshot_onindica que o banco de dados está usando isolamento de instantâneo. Como isso é possível se é proibido?

sql-server sql-server-2005
  • 1 1 respostas
  • 5951 Views

1 respostas

  • Voted
  1. Best Answer
    swasheck
    2013-06-15T11:15:31+08:002013-06-15T11:15:31+08:00

    Como observou @AlexKuznetsov, SNAPSHOTexistem READ_COMMITTED_SNAPSHOTdois níveis de isolamento diferentes. Como tal, snapshot_isolation_stateindica o primeiro, enquanto is_read_committed_snapshot_ono último. Aqui estão alguns comentários que encontrei que resumem as diferenças entre os dois:

    READ COMMITTED SNAPSHOT faz leituras otimistas e gravações pessimistas. Em contraste, SNAPSHOT faz leituras otimistas e gravações otimistas.

    ~ Bill Paetzke aqui

    e ...

    [READ_COMMITTED_SNAPSHOT] difere do nível de isolamento SNAPSHOT porque, em vez de fornecer a um leitor a última versão confirmada da linha que estava disponível quando a transação foi iniciada (SNAPSHOT ISOLATION), um leitor obtém a última versão confirmada da linha que estava disponível quando a instrução foi iniciada (READ_COMMITTED_SNAPSHOT).

    ~ Uri Dimant ( ênfase minha ), aqui

    • 7

relate perguntas

  • 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

  • Downgrade do SQL Server 2008 para 2005

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • 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

    Conceder acesso a todas as tabelas para um usuário

    • 5 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
    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
    pedrosanta Listar os privilégios do banco de dados usando o psql 2011-08-04 11:01:21 +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