Los procedimientos almacenados de MySQL , en postgreSQL se llaman funciones, pueden crearse desde consola, pero es mucho mas fácil utilizar pgAdmin.
Para este tutorial, se emplearan dos tablas que consisten en una tabla llamada PERSONA y otra tabla, llamada TORNEO, el código para su creación esta más abajo, la tabla Torneo ademas hace uso de un SEQUENCE para generar un ID autoincrementable, puedes ver un tutorial AQUI.
CREATE TABLE persona ( "CI" character(7) NOT NULL, "Nombre" character(32) NOT NULL, edad integer NOT NULL DEFAULT 18, CONSTRAINT "CI" PRIMARY KEY ("CI") ) CREATE SEQUENCE id_secuencia INCREMENT 1 MINVALUE 1 MAXVALUE 9223372036854775807 START 18 CACHE 1; ALTER TABLE id_secuencia OWNER TO postgres; CREATE TABLE torneo ( "ID" integer NOT NULL DEFAULT nextval('id_secuencia'::regclass), ci_participante character(7) NOT NULL, categoria character(16) NOT NULL, CONSTRAINT "ID" PRIMARY KEY ("ID") )
El ejemplo que crearemos es muy simple, teniendo algunos registros en la tabla PERSONA, crearemos una función que nos permita registrar participantes en la tabla TORNEO, con la restricción de que si la edad es mayor o igual de 18 años, se registren en la categoría «Mayores», caso contrario si la edad es menor de 18 años, corresponden a la categoría «Menores». Un ejemplo muy simple, pero que nos sirve para ver en su mayoría las instrucción más utilizadas en las funciones, parámetros, variables, consultas, instrucciones condicionales, etc.
la función completa la tienes en el siguiente código:
declare -- se declaran las variables a utilizar ci character(7); -- ID de tabla persona = CEDULA DE IDENTIDAD edad integer; -- la edad del participante --la funcion va entre BEGIN y END begin ci = $1 ; -- ci toma valor del parametro de entrada -- el valor de edad, sera calculado mediante una consulta a la tabla persona edad = ( select p."edad" from "persona" as p where p."CI" = ci ); -- de acuerdo al valor de EDAD registramos al participante en la categoria -- >=18 Mayores <18 Menores sino, NO SE REGISTRA NADA if( edad >= 18 ) then insert into torneo( ci_participante, categoria ) values ( ci, 'Mayores' ); return 'Participante registrado en la categoria MAYORES'; elsif ( edad <18 ) then insert into torneo( ci_participante, categoria ) values ( ci, 'Menores' ); return 'Participante registrado en la categoria MENORES'; else return 'Error: No se pudo completar el registro'; end if; end;
En el siguiente video, veremos paso a paso su construcción y ejecución
🙂 FIN
Yo soy yo :) JC Mouse, Soy orgullosamente boliviano soy fundador y CEO de la web jc-Mouse.net uno de las pocas web en emprendimiento y tecnología en Bolivia.
Toda la información que encuentres en este sitio es y sera completamente gratis siempre, puedes copiar, descargar y re-publicar si así lo deseas en otros blogs o sitios web, solo te pido a cambio que dejes una referencia a esta web. Esto nos ayuda a crecer y seguir aportando. Bye
Enjoy! :)
GraphADT es una proyecto alojado en github escrito en java que te permite trabajar con grafos, a la fecha de escribir es...
En este tutorial crearemos una aplicación android que nos permitirá abrir un PopupMenu de donde podremos seleccionar una...
En este post diseñaremos un reporte de un padrón electoral con dos columnas que contendrá los certificados de sufragio e...
En este post se da respuesta a una pregunta realizada por facebook. El problema dice así: Se quiere personalizar un JTab...
Autenticación en una pagina web es el proceso de confirmar que un usuario es quien dice ser, asi de simple. En el siguie...
Quinta parte de la serie de tutoriales «Creación de un blog siguiendo el patrón MVC (Modelo, Vista y Controlador)«. En e...
Si trabajas con redes sociales (RRSS) a continuación te muestro tres herramintas gratuitas que te ayudaran a la hora de...
Por lo general se usan transacciones a nivel base de datos y posteriormente se llaman estos a través de procedimientos a...
En este post, aprenderemos como conectar Visual Basic 6 con SQL Server, abrir una tabla, leer su contenido y mostrar est...
Lo que veremos en este post es la configuración del driver para PHP de SQL Server que ha creado Microsoft el cual permit...