Ir para conteúdo

Recommended Posts

Olá pessoal bom dia! 

 

Preciso de uma ajuda com um detalhe no banco de dados no caso é postgres v.9.4 , explicando a situação estou fazendo uma manutenção de dados de certos logs que gero e tenho exemplo uma tabela que é envios.envio_contato_log_status ela tinha mais 220GB só nela eu limpei ficou de boa (agora esta zerado e nem lista abaixo), só que ao rodar o código que mede o tamanho das tabelas vejo que tenho uma de 45GB informados como consigo apagar esse cara envios.envio_contato_log_status_pkey (chave primaria da tabela acima referida envios.envio_contato_log_status) não entendi o banco ele armazena dados nas chaves primarias, indexadores, etc...  Minha duvida se tem algo que permite eu excluir esses dados, no caso sabemos que essa tabela não é mais usada.

Mais queria manter a estrutura do campos mesmo que vazia por enquanto e eliminar apenas esses 45GB que não tenho ideia de como remover esse kara.

 

image.png.22b5d8b00a18b62dd76fd7f28c3f5bd0.png

Compartilhar este post


Link para o post
Compartilhar em outros sites

Pessoal desculpa ter aberto o chamado mais acho que ja descobri acabei de rodar um TRUNCATE TABLE e resolveu agora não tenho os 45GB, ate sumiu quando rodo para ver o tamanho de todo o meu banco, pelo o que entendi que o TRUNCATE elimina dados de transações que eram os 45GB e mantem toda a estrutura da tabela intacta(indexadores, FK, PK).  

Então resumindo para apagar todos os dados de uma tabela de forma limpa e rapida sem deixar vestígios use Truncate; 

Para poder selecionar dados com where use Delete, isto é, caso não queira apagar tudo, pois o truncate não aceita parametros adicionais (WHERE, LIMIT, etc)

 

image.png.b94063c702db3d88eb668ebed3688a29.png

 

Deixo os links que me ajudaram abaixo: 

 https://gustavomaiaaguiar.wordpress.com/2010/07/21/truncate-versus-delete-uma-explicacao-mais-detalhada/

http://www.oraclehome.com.br/2013/08/14/diferencas-entre-truncate-table-drop-table-ou-delete-from/

image.png

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por Victor Cometti
      Boa noite,
       
      Em algumas de minhas queries de insert eu atualizo quando encontro registro duplicado.
      insert into .... ON DUPLICATE KEY UPDATE ...... Só que descobrir que além de verificar a PRIMARY KEY ele verifica também campos UNIQUE (um ou outro).
      O interessante para mim seria que fizesse update só quando achasse a PRIMARY KEY duplicada e não o campo UNIQUE.
      É possível sem procedure? 
       
    • Por dungol
      Ola Pessoal,
      Comprei um script em php e Mysql e estou precisando de uma ajuda.
      É um script POS simples de vendas. Quando eu faço uma venda o recibo sai apenas o nome do cliente, o telefone e as informaçoes da compra, mas eu gostaria de adicionar neste recibo o endereço do cliente. Na tabela de compra já tem o campo endereço, mas eu não sei como fazer o script adicionar o endereço do cliente nessa  tabela. 
      Obrigada pela ajuda,
      Cristina
    • Por UPeralta
      Olá, preciso de ajuda. A minha função de fetch_object está acessando apenas a primeira linha do resultado da SELECT, mas a seleção está retornando duas linhas. Não sei o que eu estou fazendo errado.
      Class que está fazendo a consulta no banco de dados:
      <?php class permissao_grupo { //Variáveis referentes a colunas public $peg_codigo; public $peg_nome; //Variáveis padrão das classes public $con; public $sql; public $result; //Funções padrão para todas as classes public function __construct() { $this->con = new Conexao(); } public function fetch_object() { $this->result = $this->result->fetch_object(); foreach ($this->result AS $chave => $valor) { $this->$chave = $valor; } } public function num_rows() { return $this->result->num_rows; } //Funções da classe public function montaGrupoMenu() { $sql = "SELECT peg_codigo, peg_nome FROM permissao_grupo "; $this->result = $this->con->Executar($sql); return $this->result; } }  
      Class conexão
      <?php class Conexao { public $host = "localhost"; public $usuario = "root"; public $senha = ""; public $banco = "smart"; public $mysqli; public function __construct() { $this->Abrir(); } public function Abrir() { $this->mysqli = new mysqli(); $this->mysqli->connect($this->host, $this->usuario, $this->senha, $this->banco); } public function Fechar() { $mysqli->close(); } public function Executar($sql){ return $this->mysqli->query($sql); } public function fetch_object(){ print_r($this->mysqli->fetch_assoc()); } }  
      Alguém poderia me ajudar? Já tentei usar o fetch_assoc e o fetch_array para ver se funcionaria, mas também não deu certo.
    • Por Lucasw
      E aí pessoal, estou com um problema que me afrontou essa madrugada toda.
      Estou tentando duplicar valores de dentro de outro valor, porém na hora
      de duplicar eu não tenho conhecimento para um comando que crie novos IDS
      então, está dando erro a horas e eu em busca da solução.
      Podem me ajudar?
       
      INSERT INTO items_rooms (id, room_id, user_id)
      SELECT id, 15602, user_id
      FROM items_rooms WHERE room_id = '15601';
       
      (é onde está negrito que está o problema.)
       
      Bom dia a todos!
       
      CREATE TABLE `items_rooms` (
          `id` VARCHAR(23) NOT NULL,
          `user_id` INT(10) NOT NULL,
    • Por Marcones Borges
      Bom dia, esto tentando inserir dados de um formulário em duas tabelas ao mesmo tempo.
       
      Gostaria de sua ajuda!
       
      Arquivo Insere
       

      $conexao = conexao::getInstance();         // Recebe os dados enviados pela submissão         $acao  = (isset($_POST['acao'])) ? $_POST['acao'] : '';         $id    = (isset($_POST['id'])) ? $_POST['id'] : '';         $nome  = (isset($_POST['nome'])) ? $_POST['nome'] : '';         $funcao = (isset($_POST['funcao'])) ? $_POST['funcao'] : '';         $cpf   = (isset($_POST['cpf'])) ? str_replace(array('.','-'), '', $_POST['cpf']): '';         $status           = (isset($_POST['status'])) ? $_POST['status'] : '';   $sql = 'INSERT INTO historico (registro_ministro, descricao, data_registro, usuario )                VALUES(:registro_ministro, :descricao, :data_registro, :usuario )';                  $stm = $conexao->prepare($sql);             $stm->bindValue(':registro_ministro', $registro_ministro);             $stm->bindValue(':descricao', $descricao);             $stm->bindValue(':data_registro', $data_registro);             $stm->bindValue(':usuario', $usuario);             $retorno = $stm->execute();                          if ($retorno):                 echo "<div class='alert alert-success' role='alert'>Registro editado com sucesso, aguarde você está sendo redirecionado ...</div> ";             else:                 echo "<div class='alert alert-danger' role='alert'>Erro ao editar registro!</div> ";             endif;             echo "<meta http-equiv=refresh content='0;URL=ministros.php'>";         endif; $sql = 'INSERT INTO ministro (nome, cpf,  funcao, status )                VALUES(:nome, :cpf, :rg,  :funcao, :status, )';                                $stm = $conexao->prepare($sql);             $stm->bindValue(':nome', $nome);             $stm->bindValue(':cpf', $cpf);             $stm->bindValue(':status', $status);             $stm->bindValue(':funcao', $funcao);
       
      Porém só executa o ultimo código não executa o primeiro o que pode ser ?
       
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.