Seleccionar página

Copia con modificaciones de una fila en PL/PGSQL

por | Mar 4, 2011 | GNU / Linux

Copia con modificaciones de una fila en PL/PGSQL. Una operación que he necesitado hacer en una función de PL/PGSQL es copiar una fila de una tabla en la propia tabla, pero haciendo modificaciones de alguno de sus campos. Lo ideal es no necesitar conocer el resto de los campos que van a quedar igual en la copia, únicamente nos interesan los campos a modificar. He aquí la solución:

DECLARE
 node tablaacopiar%rowtype;
 newNode tablaacopiar%rowtype;
BEGIN
 FOR node IN SELECT * FROM tablaacopiar WHERE ...
   newNode := node;
   newNode.campo1='blahblha';
   newNode.otrocampo='patatin';
   INSERT INTO tablaacopiar SELECT newNode.*;
 END LOOP;
END;

0 comentarios

Enviar un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

Blog de Neodoo Microsystems
Resumen de privacidad

Esta web utiliza cookies para que podamos ofrecerte la mejor experiencia de usuario posible. La información de las cookies se almacena en tu navegador y realiza funciones tales como reconocerte cuando vuelves a nuestra web o ayudar a nuestro equipo a comprender qué secciones de la web encuentras más interesantes y útiles. Puedes encontrar más información en nuestra Política de privacidad y Política de cookies.