FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
¿Como se actualiza un campo de una tabla a partir de las columnas de otra?
Hola a todos
Pues eso, que intento actualizar el campo de una tabla con el resultado de otra Uso mySql y un ZSQLProcessor en Delphi 7 El código es el siguiente Código:
UPDATE familias SET `elementos` = ( SELECT id_area, id_familia, id_subfamilia, COUNT(`id_producto`) FROM productos WHERE `id_area`='00001' and `id_familia`='00000' and `id_subfamilia`='00000' GROUP BY id_area, id_familia, id_subfamilia ) WHERE `id_area`='00001' and `id_familia`='00000' and `id_subfamilia`='00000'; Gracias adelantadas Salvador Lo he modificado a como creo que debia de ir aunque tampoco funciona Última edición por salvica fecha: 08-07-2004 a las 19:20:11. |
#2
|
||||
|
||||
Wop!
Te sobra el order by
__________________
E pur si muove |
#3
|
||||
|
||||
Perdona, con las prisas me he colado
es GROUP BY Y el caso es que he encontrado otro parecido en el foro y lo hago igual Gracias |
#4
|
||||
|
||||
Wop!
No estoy muy puesto en mysql, pero en SQL estandard encunetro dos errores conceptuales: -Teoricamente la subselect puede retornar más de un registro... y en updates solamente debe retornar uno. - Estás haciendo un SET de un campo y la query retorna más de uno.
__________________
E pur si muove |
#5
|
||||
|
||||
Gracias por contestar Marto
He ejecutado con MySQL Control Center (a "pelo") la query Código:
SELECT id_area, id_familia, id_subfamilia, COUNT(`id_producto`) FROM productos WHERE `id_area`='00001' and `id_familia`='00000' and `id_subfamilia`='00000' GROUP BY id_area, id_familia, id_subfamilia ¿Hay alguna forma de asignar la salida anterior a una variable y el valor se ésta usarlo para actualizar la primera tabla? En Oracle (hace unos años) hice algo parecido con CREATE VIEW, pero en el manual de mySql parece que no lo admite |
#6
|
||||
|
||||
Perdona... pero esa consulta no puede dar como resultado "4", ya que preguntas por tres campos ademas del count... y digo yo que aunque sea null, algun valor devolverán
__________________
E pur si muove |
#7
|
||||
|
||||
Prueba con esto
__________________
E pur si muove |
#8
|
||||
|
||||
LLevas razón, marto (pensaba que los campo de agrupamiento debian estar en la select)
Entonces la query que me dá 4 queda tal y como así Código:
SELECT COUNT(`id_producto`) FROM productos WHERE `id_area`='00001' and `id_familia`='00000' and `id_subfamilia`='00000' GROUP BY id_area, id_familia, id_subfamilia; |
#9
|
||||
|
||||
Sin embargo, me dice:
Cita:
Saludos |
#10
|
||||
|
||||
Te sobra el froup by.
Los campos por los que quieres agrupar ya son los que fijas en el where... por lo tanto no tiene sentido la agrupación.
__________________
E pur si muove |
#11
|
||||
|
||||
Vamos a ver, si tengo en productos los siguientes registros
Código:
id_area id_familia id_subfamilia id_producto 00001 00000 00000 00001 00001 00000 00000 00002 00001 00000 00000 00003 00001 00001 00000 00001 00001 00001 00000 00002 00002 00001 00001 00001 00002 00001 00001 00002 00002 00001 00002 00001 00002 00002 00002 00001 00002 00002 00002 00002 00002 00002 00002 00003 Código:
id_area id_familia id_subfamilia elementos 00001 00000 00000 3 00001 00001 00000 2 00002 00001 00001 2 00002 00001 00002 1 00002 00002 00002 3 Creo una orden por cada familia (si sabeis la forma de automatizarlo en un solo paso, mejor que mejor) De todas formas gracias por hacerme caso Última edición por salvica fecha: 09-07-2004 a las 00:32:24. |
#12
|
||||
|
||||
¿Tu has probado lo que te he indicado antes? Si no se me ha escapado nada, eso tendría que funcionar. Si no, dime en qué falla...
__________________
E pur si muove |
#13
|
||||
|
||||
Lo probé y me sigue dando el error que me da en la mía
Cita:
Código:
SET `elementos` = ( SELECT COUNT(`id_producto`) |
|
|
|