Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 27-01-2011
Avatar de microbiano
microbiano microbiano is offline
Miembro
 
Registrado: sep 2008
Ubicación: Mexico D.F
Posts: 349
Poder: 16
microbiano Va por buen camino
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.
Responder Con Cita
  #2  
Antiguo 27-01-2011
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
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
Responder Con Cita
  #3  
Antiguo 27-01-2011
Avatar de microbiano
microbiano microbiano is offline
Miembro
 
Registrado: sep 2008
Ubicación: Mexico D.F
Posts: 349
Poder: 16
microbiano Va por buen camino
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')
Responder Con Cita
  #4  
Antiguo 28-01-2011
Avatar de microbiano
microbiano microbiano is offline
Miembro
 
Registrado: sep 2008
Ubicación: Mexico D.F
Posts: 349
Poder: 16
microbiano Va por buen camino
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?
Responder Con Cita
  #5  
Antiguo 28-01-2011
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por microbiano Ver Mensaje
que opcion es la mejor. la primer o la segunda?
Pues, la que te funcione mejor

// Saludos
Responder Con Cita
  #6  
Antiguo 28-01-2011
Avatar de microbiano
microbiano microbiano is offline
Miembro
 
Registrado: sep 2008
Ubicación: Mexico D.F
Posts: 349
Poder: 16
microbiano Va por buen camino
si verdad, lo importante fue resolver en su momento el problrma gracias Roman
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Ayuda Con Update microbiano Conexión con bases de datos 5 01-09-2010 23:51:12
ayuda con un update ingmichel MS SQL Server 12 29-03-2008 00:51:25
Update despues de Consulta anghell77 SQL 8 25-05-2006 09:57:10
consulta update majosf Conexión con bases de datos 1 17-09-2005 15:09:04


La franja horaria es GMT +2. Ahora son las 09:55:12.


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