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 / 34784
Accepted
JHFB
JHFB
Asked: 2013-02-15 12:36:31 +0800 CST2013-02-15 12:36:31 +0800 CST 2013-02-15 12:36:31 +0800 CST

Uma tabela deve ser particionada antes ou depois de um INSERT?

  • 772

Eu tenho uma pergunta bastante simples que está sendo difícil de pesquisar.

Preciso criar uma tabela que será particionada e na qual (muitos) dados serão carregados.

É mais eficiente criar a tabela com as partições ou adicionar as partições depois de inserir os dados?

ADIÇÃO: Para ter certeza de que entendi a imagem completa, se eu fosse truncar esta tabela para carregar (muitos) dados novamente, devo descartar as partições e adicionar após o carregamento?

ADIÇÃO #2: Se eu puder INSERIR os dados na ordem das partições, suponho que seria mais rápido do que não?

oracle-11g-r2
  • 1 1 respostas
  • 2705 Views

1 respostas

  • Voted
  1. Best Answer
    Justin Cave
    2013-02-15T12:40:36+08:002013-02-15T12:40:36+08:00

    Você não pode particionar uma tabela não particionada existente. Portanto, se você quiser uma tabela particionada, precisará criar uma tabela particionada antes de inserir qualquer dado.

    Supondo que você não esteja usando o particionamento de intervalo (caso em que você está dizendo ao Oracle como adicionar automaticamente novas partições com base nos dados), é quase certo que você deseja criar as partições apropriadas com antecedência. Se você estiver particionando a tabela por intervalo, poderá, em teoria, criar uma partição MAXVALUE para a tabela, carregar todos os dados e, em seguida, dividir a partição MAXVALUE nas partições individuais que desejar. Mas isso envolveria mover todos os dados várias vezes, o que seria muito menos eficiente do que simplesmente carregar os dados na partição apropriada desde o início.

    Inserir os dados "na ordem das partições" provavelmente não fará diferença do ponto de vista do desempenho. O Oracle ainda precisa determinar para cada linha em qual partição inseri-la. Supondo que seus índices sejam locais, pode ser mais eficiente carregar uma tabela de preparação cuja estrutura corresponda à estrutura de uma partição, criar os índices apropriados na tabela de preparação e, em seguida, fazer uma troca de partição para trocar uma partição vazia com a tabela de preparação .

    • 6

relate perguntas

  • Como uma exportação de datapump pode ter seu uso de recursos limitado no Windows?

  • Como uma exportação de datapump pode ter seu uso de recursos limitado no linux?

  • Por que a autenticação do sistema operacional é considerada uma segurança ruim para bancos de dados Oracle?

  • Como você versiona as alterações do banco de dados Oracle?

  • Existe uma maneira de permitir que uma conexão proxy use autenticação passada em um link de banco de dados público?

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