Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   ayuda con consulta update (https://www.clubdelphi.com/foros/showthread.php?t=72102)

microbiano 27-01-2011 19:34:28

ayuda con consulta update
 
resulta que tengo una tabla de nombre captura ejemplo
col1--col2--precio_ref--precio_dif
060 --20---10.50 ---
060--20---10.60-------X


y tengo otra tabla que se llama requerimiento con la siguiente estructura

col1--col2--precio_ref--precio_dif
060 --20---10.50 ---


bien resulta que quiero ponerle una X a la clave que tiene diferente el precio
y lo quiero hacer de la siguiente manerta.

Código SQL [-]
UPDATE CAPTURA SET PRECIO_DIF='X'
WHERE precio_ref<>(select precio_ref from requerimiento where licitacion='LA-019GYR047-T25-2010')

pero no me funciona
me manda el siguiente error

Servidor: mensaje 512, nivel 16, estado 1, línea 1
La subconsulta ha devuelto más de un valor, lo que no es correcto cuando va a continuación de =, !=, <, <=, >, >= o cuando se utiliza como expresión.
Se terminó la instrucción.


la base es sql2000... alguna sugerencia.

roman 27-01-2011 22:26:55

Bueno, el campo precio_ref en el where sólo puede compararse con un valor, por eso el mensaje de error que te dice que la subcosulta devuelve más de un valor. Es decir, piensa en el update como que recorre uno a uno todos los registros y, por cada uno, ejecuta la subconsulta y compara el valor de precio_ref con lo que devuelve dicha subconsulta. Pero so hay más de un registro en la subconsulta, ¿con cuál compararía?

Para solucionar esto, tendrías que restringir la subconsulta para que te devuelva sólo el valor que corresponda al registro actual, por ejemplo:

Código SQL [-]
update captura
set precio_dif = 'X'
where precio_ref <> (
  select precio_ref from requerimiento
  where
    licitacion='LA-019GYR047-T25-2010' and
    requerimiento.col1 = captura.col1 and
    requerimiento.col2 = captura.col2
)

Pero, aun esto dependerá de que en tu tabla requerimiento no se repitan registros con los mismos valores de col1 y col2. Podrían repetirse, pero no para la misma licitación.

// Saludos

microbiano 27-01-2011 23:38:23

gracias
 
hola roman es poco probable que existe un registro identico con los mismo valores en la tabla requerimiento, sin embargo no he checado la propuesta que pones debido a que lo solucione de la siguiente manera aun asi voy a probar tu propuesta:

Código SQL [-]
UPDATE captura
SET precio_dif='X'
WHERE exists(select id_zona,gpo,gen,esp,dif,[var],precio_ref
from requerimiento as b
where
captura.licitacion=b.licitacion and
captura.id_zona=b.id_zona and
captura.gpo=b.gpo and
captura.gen=b.gen and
captura.esp=b.esp and
captura.dif=b.dif and
captura.[var]=b.[var] and
captura.precio_ref<>b.precio_ref) and licitacion in('LA-019GYR047-T25-2010')

microbiano 28-01-2011 03:03:37

Otra sugerencia
 
Estimado Roman.


probe la sugerencia para hacer las modificaciones y te voy a decir que fue de maravilla jejejeje aveces es buscar la solucion. jejej ahora la pregunta es?

Código SQL [-]
update captura
set precio_dif = 'X'
where precio_ref <> (
  select precio_ref from requerimiento
  where
    licitacion='LA-019GYR047-T25-2010' and
    requerimiento.id_zona=captura.Id_zona and    
    requerimiento.gpo = captura.gpo and
    requerimiento.gen = captura.gen and
    requerimiento.esp = captura.esp and  
    requerimiento.dif = captura.dif and
requerimiento.[var] = captura.[var] and
requerimiento.precio_ref <> captura.precio_ref)
que opcion es la mejor. la primer o la segunda?

roman 28-01-2011 15:48:17

Cita:

Empezado por microbiano (Mensaje 389119)
que opcion es la mejor. la primer o la segunda?

Pues, la que te funcione mejor :D

// Saludos

microbiano 28-01-2011 16:01:32

si verdad, lo importante fue resolver en su momento el problrma gracias Roman


La franja horaria es GMT +2. Ahora son las 16:24:40.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi