Ver Mensaje Individual
  #13  
Antiguo 03-08-2005
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Reputación: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Lo que sugiero es, primero, que te tomes un tiempo en revisar la sintaxis y uso de la sentencia INSERT. Hasta donde yo conozco, el uso de VALUES es para la inserción de un sólo registro. Aunque algunos motores extienden la sintaxis para múltiples registros, los registros insertados son estáticos en el sentido de que debes proveer explícitamente los valores de los campos. Por otra parte, la sentencia INSERT INTO ... SELECT se usa para la inserción de registros provenientes de otra tabla.

Cuando originalmente pregunté si Interbase soportaba este tipo de sentencia (cosa que supongo que es así aun cuando no lo sé a ciencia cierta, pero me baso en la máxima: si algo funciona en Paradox- base con la que probé lo que he sugerido -debe funcionar en casi cualquier otro motor; derivada su vez de la máxima: menos potente que Paradox sólo DBase) lo hice con la intención de decir que no era necesario un ciclo para la inserción de los registros sino que bastaba una sóla sentencia SQL.

En segundo lugar te sugiero que revises el uso de parámetros en sentencias SQL- '1001' no puede ser el nombre de un parámetro.

En tercer lugar una crítica constructiva que espero no tomes a mal porque no la hago con ánimo de molestar ni ofender.

He leído muchos de tus mensajes, dudas e intentos por resolverlas y considero que atacas los problemas con la técnica de "dar palos de ciego".

Preguntas aquí y allá, modificas esto y lo otro, quitas líneas y agregas otras esperando que alguno de los cambios resulte. Pero de esta forma, aunque eventualmente puedes llegar a la solución, tardas mucho más de lo que tardarías si te detuvieras a analizar lo que estás haciendo, a plantear (primero a ti y luego a los demás) de forma clara el problema en cuestión, y a estudiar libros o manuales. No se trata de poner VALUES y probar, quitar VALUES y probar. Si ya te has dado cuenta de que la sentencia INSERT tiene distintas modalidades entonces tómate un tiempo en revisar la sintaxis en un manual antes de "dar palos de ciego".

Tal como planteas el problema, no hacen falta ni triggers ni ciclos sino una sóla sentencia INSERT .. SELECT; eso sí, con sus parámetros bien colocados y sustituídos.

// Saludos
Responder Con Cita