Arquivo da categoria: PostgreSQL

PostgreSQL – A simple SQL Query Builder

Share and Enjoy !

0Shares
0 0

Verificar e finalizar conexões ativas no PostgreSQL

Como verificar conexões ativas no PostgreSQL

Para conseguir listar o número de conexões ativas no PostgreSQL utilize o comando:

select * from pg_stat_activity;

conexoes_postgresql_mini

Você pode utilizar o comando count() para contar as conexões.

select count(*) from pg_stat_activity;

É possível filtrar por Banco de Dados colocando na clausula “where” o banco desejado.

Ex.:

select * from pg_stat_activity where datname = ‘NOME_DO_BANCO’;

Finalizar Conexões

Para finalizar conexões você pode utilizar a função abaixo passando como parâmetro o número do pid. O pid é obtido através do select na tabela pg_stat_activity.

Atenção: Esse comando não existe em versões do PostgreSQL  inferiores a 8.4.

select pg_terminate_backend(pid);

Obs.: A coluna “pid” em versões inferiores a 9.2 do PostgreSQL tinha o nome de “procpid”.

É possível finalizar todas as conexões menos a sua conexão através da query abaixo.

SELECT pg_terminate_backend(pid)
FROM pg_stat_activity
WHERE pid <> pg_backend_pid();

Share and Enjoy !

0Shares
0 0

ruby on rails value Rails reset ALL Postgres sequences?

ActiveRecord::Base.connection.tables.each do |table|
  result = ActiveRecord::Base.connection.execute("SELECT id FROM #{table} ORDER BY id DESC LIMIT 1") rescue ( puts "Warning: not procesing table #{table}. Id is missing?" ; next )
  ai_val = result.any? ? result.first['id'].to_i + 1 : 1
  puts "Resetting auto increment ID for #{table} to #{ai_val}"
  ActiveRecord::Base.connection.execute("ALTER SEQUENCE #{table}_id_seq RESTART WITH #{ai_val}")
end
https://code-examples.net/en/q/1b64931

Share and Enjoy !

0Shares
0 0

How to reset PG Database on Heroku?

How to reset PG Database on Heroku?

  • Step 1: heroku restart
  • Step 2: heroku pg:reset DATABASE (no need to change the DATABASE)
  • Step 3: heroku run rake db:migrate
  • Step 4: heroku run rake db:seed (if you have seed)

One liner

heroku restart; heroku pg:reset DATABASE --confirm APP-NAME; heroku run rake db:migrate

Note 1

Heroku doesn’t allow users from using rake db:resetrake db:drop and rake db:create command. They only allow heroku pg:reset and rake db:migrate commands.

More info: https://devcenter.heroku.com/articles/rake

Note 2

If you have more than 1 remote, append --remote [your_remote_name] like this:

heroku run rake db:migrate --remote dev (dev is example remote here)

https://gist.github.com/zulhfreelancer/ea140d8ef9292fa9165e#how-to-reset-pg-database-on-heroku

Share and Enjoy !

0Shares
0 0