Passa ai contenuti principali

PostgreSQL: Copiare una tabella da un database ad un altro

A volte può essere utile avere un modo veloce per poter far comunicare due database diversi in  una sessione di utilizzo di un database PostgreSQL. Senza dover passare per un programma specifico questo RDBMS ci viene in aiuto con un modulo esterno: dblink. La limitazione è data dal fatto che i due database devono essere su server PostgreSQL.

Installare dblink


Scenario
Vediamo come impostare una connessione tra database diversi e come utilizzare questo strumento per una semplice copia tra tabelle. Notare che i passi che seguono sono espressamente dedicati ad un ambiente GNU\Linux. Lo scenario è quello di avere un unico server in locale chiamato pgserver e due database diversi chiamati source e dest. Nel database source abbiamo una tabella ts con campi name e description e nel database dest abbiamo una tabella td con campi nome e descrizione.


Prerequisiti
Avere un database PostgreSQL installato.

Procedura
Installare se non presente il pacchetto contenente i moduli aggiuntivi per il server

sudo apt-get install postgresql-contrib

Ora dobbiamo installare il modulo dblink sul database dal quale vogliamo eseguire la connessione, nel nostro caso il database destinazione della copia. Cerchiamo con il seguente comando la posizione corretta dello script di installazione da eseguire

sudo find / -name dblink.sql

Il risultato sarà verosimilmente del tipo
/usr/share/postgresql/8.4/contrib/dblink.sql
Eseguiamo lo script con il comando seguente e abbiamo terminato

psql -d dest -U postgres -f /usr/share/postgresql/8.4/contrib/dblink.sql

Esempio pratico

Come esempio più semplice possiamo usare il dblink per copiare i dati della tabella sorgente ts del database source in quella destinazione td del database dest eseguendo la query ovviamente da dest.
INSERT INTO td(nome, descrizione)
SELECT * FROM dblink('dbname=source',
         'SELECT name, description FROM ts')
         AS tmp1 (name text, description text);

Link utili

http://stackoverflow.com/questions/3862648/how-to-use-install-dblink-in-postgresql
http://www.postgresonline.com/journal/archives/44-Using-DbLink-to-access-other-PostgreSQL-Databases-and-Servers.html

Post popolari in questo blog

Se excel non aggiorna le formule

Oggi in ufficio è capitata una richiesta particolare. In un documento excel dopo aver eseguito un copia-incolla di una formula non si aggiornavano i risultati nelle celle interessate. Dopo attimi di perplessità dal fondo dell'ufficio il capo ci illumina con una funzione ai più sconosciuta e che ha risolto il problema: il tasto F9. Scusate la mia ignoranza in excel ma questo blog è pensato proprio per appuntare esperienze di vita informatica. Tutto sta nel fatto che i "calcolatori d'un tempo" non disponevano di una adeguata potenza di calcolo e nelle operazioni di copia-incolla si verificavano lunghe attese per l'aggiornamento. La soluzione adottata da MS è stata quella di inserire un'opzione per impedire l'aggiornamento automatico e forzarlo con una combinazione di tasti... il tasto F9!
Combinazioni utili per il calcolo delle formule F9 = calcola le formule modificate dall'ultimo calcolo in tutte le cartelle e fogli di lavoro aperte. MAIUSC + F9 = c…

Dove si trova il mio ISP?

Il link di oggi è My IP Address Lookup. Questo servizio spagnolo mostra dove si trova fisicamente il vostro ISP. Quando vi collegate ad internet in realtà prima fate una richiesta (il vostro modem o router) ad una macchina del vostro ISP e poi vi viene assegnato un indirizzo IP. Se volete sapere dove si trova la macchina che vi permette di accedere alla rete visitate pure
http://www.ip-adress.com/

Potrete inoltre conoscere il vostro IP e il provider che ve lo offre

RaspberryPi: Abilitare l'audio analogico

Introduzione
Il mio raspi è collegato ad una vecchia TV CRT che ho convertito in una smartTV. RaspberryPi infatti è un ottimo prodotto per configurare un media center con connessione ad internet ed altre amenità. Se usate una vecchia TV come nel mio cavo potrebbe interessarvi come abilitare l'uscita analogica per l'audio, il jack da 3,5 mm per intenderci. Per fare ciò dobbiamo assicurarci di avere i moduli giusti del kernel caricati e configurare il raspi ad utilizzare la giusta uscita audio, infatti di default utilizza la porta HDMI.

Controllo della presenza del modulo snd_bcm2835
1 Per controllare che il modulo giusto sia presente da linea di comando eseguire

sudo lsmod | grep snd_bcm2835

2 Se non vedete alcun output vuol dire che il modulo non è ancora caricato altrimenti potete passare al prossimo paragrafo.
3 Proviamo a caricare  il modulo con il seguente comando da terminale

sudo modprobe snd_bcm2835

Se l'output del comando è una cosa del genere

FATAL: Module snd_bcm2835…