![]() |
Insertar registros
Hola amigos
Tengo poca experiencia en sql. Me gustaría saber si es posible que en una sentencia puedan insertarse registros en una tabla que sean el resultado de un 'select'. Es decir, quiero hacer un 'select' y que el grupo de registros devueltos se inserten en una tabla. La idea es grabar una tabla temporal a partir de una consulta, y que esta tarea la haga el servidor directamente. Así evitar que el resultado venga al ordenador cliente y de este se grabe el temporal en el servidor, haciendo viajar los datos por la red como locos. No se si me he explicado bien. Utilizo interbase. Gracias y saludos |
lo estas programando en delphi
|
Cita:
|
Depende de lo que quieras hacer, ejemplo:
Obviamente, en este caso las tablas deben ser iguales. Y aquí da igual el delphi, es sql, lo puedes poner en un stored procedure de la base de datos y lanzarlo cuando lo necesites. Por cierto, procura poner títulos descriptivos a tus preguntas, gracias :) |
Cita:
Por poner un ejemplo sencillo, hacer un select de la tabla LINEAS DE FACTURA, para obtener los artículos vendidos. A su vez realizar un left join para obtener el cabezal de la factura y obtener el campo FECHA para descartar los que no queremos. Y también un left join con la tabla ARTICULOS para obtener la descripción del articulo. El resultado (varios registros) grabarlos en la tabla VENTAPERIODO que tendría los campos p.e. ARTICULO, CANTIDAD, PRECIO, IMPORTE, DESCRIPCION, ... Este sería un ejemplo sencillo. Lógicamente la consulta sería mucho más complicada. Supongo que desde SQL puro no puedo hacerlo, pero quizá sí con stored procedures? |
Cita:
En SQL se puede hacer todo, lo que tienes que hacer es crearte una tabla con los campos igualmente definidos que vas a necesitar de las tres tablas y crear la SQL que recoja los campos que vas a grabar.
Un saludo. |
Cita:
Anda! Es exactamente lo que quería y no tenía ni idea de si se podía hacer. He probado con IBExpert con una consulta sencilla grabando en una tabla temporal y HA FUNCIONADO PERFECTAMENTE !!! #:-)##:-)# Gracias a todos por las respuestas v:-)v |
La franja horaria es GMT +2. Ahora son las 17:29:20. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi