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 / 225015
Accepted
Mark Freeman
Mark Freeman
Asked: 2018-12-15 08:32:18 +0800 CST2018-12-15 08:32:18 +0800 CST 2018-12-15 08:32:18 +0800 CST

Por que existem vários planos de consulta sob parametrização forçada?

  • 772

Eu vejo a seguinte consulta em um Banco de Dados SQL do Azure (que tem Parametrização Forçada = FORCED, Parameter Sniffing = ON e Query Optimizer Fixes = ON) de dentro do Repositório de Consultas:

delete from [CMS_WebFarmTask] 
where [TaskIsAnonymous] = @0 
and [TaskID] not in ( select [TaskID] from [CMS_WebFarmServerTask] ) 
and [TaskCreated] < dateadd ( minute , @1 , getdate ( ) )

Possui um grande número de planos (17 na última hora), apesar de ambos os parâmetros serem inteiros com valores idênticos em cada plano:

        <ParameterList>
          <ColumnReference Column="@1" ParameterDataType="int" ParameterCompiledValue="(-3)" />
          <ColumnReference Column="@0" ParameterDataType="int" ParameterCompiledValue="(0)" />
        </ParameterList>

Captura de tela do repositório de consultas

Por que apenas um plano não está sendo usado?

azure-sql-database execution-plan
  • 1 1 respostas
  • 103 Views

1 respostas

  • Voted
  1. Best Answer
    LowlyDBA - John M
    2018-12-15T08:48:12+08:002018-12-15T08:48:12+08:00

    Parametrização forçada <> plano único forçado.

    No entanto, o Repositório de Consultas tem um recurso para forçar um plano único, se é isso que você procura. Você pode ver o botão para isso diretamente na sua captura de tela.

    Mas, se sua preocupação for mais geral sobre o motivo pelo qual você está recebendo vários planos, você deve começar certificando-se de que a mesma consulta esteja sendo executada todas as vezes. No seu caso, como você está usando GETDATE(), a consulta é realmente diferente toda vez que é executada, então eu não esperaria que ela produzisse o mesmo plano necessariamente com base apenas nisso.

    Você também precisa estar ciente do fato de que as estatísticas das tabelas subjacentes também podem mudar ao longo do tempo, o que pode afetar fortemente as estimativas do plano. Existem muitos outros fatores que contribuem para isso - este artigo se aprofunda no que entra em um plano de execução e o que pode afetá-lo. O banco de dados é uma coisa viva e a mudança de plano não deve ser inerentemente vista como algo ruim, a menos que esteja causando problemas óbvios de desempenho.

    • 2

relate perguntas

  • Servidor vinculado ao SQL Azure muito lento

  • Como posso alterar uma chave primária existente no SQL Azure?

  • O código cria um plano diferente quando executado ad-hoc em comparação com um procedimento armazenado

  • Exibir consulta subjacente do SQL 2008 sp_cursorexecute e plano de execução

  • Noções básicas do plano de execução - confusão de correspondência de hash

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    conectar ao servidor PostgreSQL: FATAL: nenhuma entrada pg_hba.conf para o host

    • 12 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

    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
    Jin conectar ao servidor PostgreSQL: FATAL: nenhuma entrada pg_hba.conf para o host 2014-12-02 02:54:58 +0800 CST
  • 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
    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