Em python podes-te ligar a PostgreSQL e realizar uma consulta:<div><br><div><div>-----------------------------------------</div><div>    import psycopg2</div><div>    import getpass</div><div>    password = getpass.getpass('Senha: ')</div>

<div>    conn = psycopg2.connect("dbname='nome_bd' user='utilizador' host='host' password='%s'" % password);</div><div>    cur = conn.cursor()</div><div>    cur.execute("SELECT campo1, campo2 FROM tabela WHERE campo = 'blah' ")</div>

<div>    rows = cur.fetchall()</div><div>    for row in rows:</div><div>        campo1 = row[0]</div><div>        campo2 = row[1]</div><div>        print campo1, campo2</div><div>-----------------------------------------</div>

<div><br></div><div>Espero que seja útil.</div><div>Cumprimentos,</div><div><br></div>Eloi Ribeiro<br>GIS Analyst<br>39,45º -0,40º<br><a href="http://flavors.me/eloiribeiro" target="_blank">flavors.me/eloiribeiro</a><br>

<br><br><div class="gmail_quote">No dia 9 de Julho de 2012 23:55, Filipe Brandão <span dir="ltr"><<a href="mailto:fgbrandao@emepc-portugal.org" target="_blank">fgbrandao@emepc-portugal.org</a>></span> escreveu:<br>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Boa noite.<br><br>Gostaria de saber se alguém me pode ajudar num problema que estou a tentar resolver.<br>Cenário: Tenho uma BD com duas tabelas. A primeira só tem uma linha, que se pode editar (update) via user form. Cada vez que essa mesma linha é editada, é populada a 2ª tabela (com um trigger que dispara sempre que há um update na 1ª tabela), de modo incremental (insert). Deste modo tenho um historial de todas as interacções entre utilizadores e a 1ª tabela.<br>


Criei outro trigger para enviar emails aos users que interajam com a 1ª tabela (um dos campos que preenchem é um endereço de email), também depois de haver updates nessa mesma 1ª tabela. Este trigger dispara um script em python que faz esse mesmo envio.<br>


Preciso ainda que cada vez que haja um envio, este seja feito para o ultimo endereço a ser inserido na 2ª tabela (tenho um atributo com datatype serial, para saber sempre qual a ultima linha da tabela). Até aqui tudo ok.<br>


Agora o problema. Quando há um update na 1ª tabela os dois triggers disparam e correm, mas no caso do envio de emails é sempre enviado o email para o <b><u>ultimo registo da tabela antes desse mesmo update</u></b>!<br>Ou seja, há uma transacção em curso e o trigger "não vê" o ultimo registo uma vez que ainda não foi feito um commit na BD, que só acontece depois de a transacção acabar.<br>


Já vi que não é possível disparar triggers depois de triggers, que não consigo fazer commit a meio de uma transacção, etc.<br>Como poderei dar a volta a isto?<br>Aquilo que me pareceu mais óbvio era aproveitar o primeiro trigger de que vos falei, uma vez que nele consigo ir buscar os novos valores da 1ª tabela (que depois são inseridos na 2ª). Mas não consegui programar o script em python para incluir essa mesma função.<br>


A função é basicamente isto, e funciona bem (ele saca o new.email para a 2ª tabela):<br><pre>CREATE OR REPLACE FUNCTION process_emp_audit() RETURNS TRIGGER AS $emp_audit$
    BEGIN

        IF (TG_OP = 'UPDATE') THEN
            INSERT INTO emp_audit SELECT 'D', now(), user, <font size="4"><b><u>NEW.email</u></b></font>;
        END IF;<br><br>        RETURN NULL; -- result is ignored since this is an AFTER trigger
    END;
$emp_audit$ LANGUAGE plpgsql;

CREATE TRIGGER emp_audit
AFTER UPDATE ON emp
    FOR EACH ROW EXECUTE PROCEDURE process_emp_audit();</pre>A função em python já a tenho escrita e funciona bem (neste momento não tenho aqui o código).<br>Precisava apenas de conseguir definir uma variável no python que me desse o valor do <b><u>NEW.email</u></b>, do género recipient = select NEW.email from emp;<br>


Alguma ideia de como ir sacar aquele new.email e usar como variável no script em python?<br><br>Obrigado a todos e espero ter-me feito entender...<span class="HOEnZb"><font color="#888888"><br><br>Filipe<br><br>
</font></span><br>_______________________________________________<br>
Portugal mailing list<br>
<a href="mailto:Portugal@lists.osgeo.org">Portugal@lists.osgeo.org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/portugal" target="_blank">http://lists.osgeo.org/mailman/listinfo/portugal</a><br>
<br></blockquote></div><br></div></div>