PostgreSQL
 sql >> база данни >  >> RDS >> PostgreSQL

Как да търсите конкретна стойност във всички таблици (PostgreSQL)?

Какво ще кажете за изхвърляне на съдържанието на базата данни, след което да използвате grep ?

$ pg_dump --data-only --inserts -U postgres your-db-name > a.tmp
$ grep United a.tmp
INSERT INTO countries VALUES ('US', 'United States');
INSERT INTO countries VALUES ('GB', 'United Kingdom');

Същата помощна програма pg_dump може да включва имена на колони в изхода. Просто променете --inserts към --column-inserts . По този начин можете да търсите и конкретни имена на колони. Но ако търся имена на колони, вероятно щях да изхвърля схемата вместо данните.

$ pg_dump --data-only --column-inserts -U postgres your-db-name > a.tmp
$ grep country_code a.tmp
INSERT INTO countries (iso_country_code, iso_country_name) VALUES ('US', 'United  States');
INSERT INTO countries (iso_country_code, iso_country_name) VALUES ('GB', 'United Kingdom');


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. PostgreSQL вътрешности:Какво е „resjunk“?

  2. SQL:Когато става въпрос за НЕ В и НЕ РАВНО НА, кое е по-ефективно и защо?

  3. Групиране по интервали от данни

  4. Как да получа локални данни в база данни само за четене с помощта на dplyr?

  5. Нулирайте първичния ключ на PostgreSQL на 1