Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > MS SQL Server
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 05-11-2010
Ledian_Fdez Ledian_Fdez is offline
Miembro
 
Registrado: jun 2006
Ubicación: Ciudad Habana, Cuba
Posts: 242
Poder: 18
Ledian_Fdez Va por buen camino
Question Procedure

Hola chicos !!!

Tengo la tabla Producto con una series de campos, donde IdProducto es mi llave primaria, quisiera validar que el campo código no se me repita es desir que sea unico.

Les muestro el código que empleo para el Insert y Update. Por favor me podrian ayudar?
No se si se podrá contralar con Trigger y en ese caso ¿cómo? o modificando el precedimiento que mas abajo le muestro.

Código SQL [-]
CREATE    procedure ActualizaProducto

@IdProducto int,
@Codigo char(3),
@Descripcion varchar(50),
@UM int,
@Periodicidad int,
@TipoProducto int,
@Identity int OUTPUT 

AS

if (@IdProducto = -1)
  begin 
    insert into Producto(Codigo, Descripcion, idUM, idPeriodicidad, IDTipoProducto)
    values (@Codigo, @Descripcion, @UM, @Periodicidad, @TipoProducto)

    set @Identity = SCOPE_IDENTITY();
  end
else
  begin 
    update Producto
    set Codigo = @Codigo,
        Descripcion = @Descripcion, 
        idUM = @UM,
        idPeriodicidad = @Periodicidad,
        IDTipoProducto = @TipoProducto
    where (IdProducto = @IdProducto) 

    set @Identity = @IdProducto
  end

GO

Salu2.

Última edición por Ledian_Fdez fecha: 05-11-2010 a las 16:57:11.
Responder Con Cita
  #2  
Antiguo 05-11-2010
Avatar de mightydragonlor
[mightydragonlor] mightydragonlor is offline
Miembro Premium
 
Registrado: feb 2007
Ubicación: Medellín-Colombia
Posts: 587
Poder: 18
mightydragonlor Va por buen camino
Código SQL [-]
Select * from tabla where IdProducto  = @IdProducto 
If @@ROWCOUNT = 0
BEGIN
   --Acá llega si no encontró registros
END
__________________
mas confundido que Garavito el día del Niño.
Responder Con Cita
  #3  
Antiguo 05-11-2010
Ledian_Fdez Ledian_Fdez is offline
Miembro
 
Registrado: jun 2006
Ubicación: Ciudad Habana, Cuba
Posts: 242
Poder: 18
Ledian_Fdez Va por buen camino
Lightbulb ¿mensaje?

Me parece muy bien, pero ahora otra pregunta ¿Podre lanzar algun mensaje? para que el usuario sepa que ya existe ese codigo.


Salu2 y mil Grasias
Responder Con Cita
  #4  
Antiguo 05-11-2010
Avatar de mightydragonlor
[mightydragonlor] mightydragonlor is offline
Miembro Premium
 
Registrado: feb 2007
Ubicación: Medellín-Colombia
Posts: 587
Poder: 18
mightydragonlor Va por buen camino
para eso deberías tener 2 variables de salida, la primera es un entero, si todo pasa bien le pasas un 0 si no, algo diferente, en tu programa preguntas si esa variable es deferente de 0 pues muestras el mensaje de error.
__________________
mas confundido que Garavito el día del Niño.
Responder Con Cita
  #5  
Antiguo 26-11-2010
Ledian_Fdez Ledian_Fdez is offline
Miembro
 
Registrado: jun 2006
Ubicación: Ciudad Habana, Cuba
Posts: 242
Poder: 18
Ledian_Fdez Va por buen camino
Question Evitar duplicar el valor de un campo desde SQL Server

Hola Desphianos:

Ya he resuelto grasias a mightydragonlor el controlar por la aplicación (que es desde donde llamo al procedimiento almacenado) que no me inserten dos códigos iguales, pero ahora ¿Cómo podré controlarlo dentro del SQL?; quiero desir al abrir la tabla por dentro del SQL Server no me puedan al insertar o modificar duplicar el código?

Mil grasias de antemano,
En espera de su ayuda

Salu2,
Ledian.
Responder Con Cita
  #6  
Antiguo 26-11-2010
Avatar de mightydragonlor
[mightydragonlor] mightydragonlor is offline
Miembro Premium
 
Registrado: feb 2007
Ubicación: Medellín-Colombia
Posts: 587
Poder: 18
mightydragonlor Va por buen camino
para ese casi necesitarias usar triggers en before insert y before update.
__________________
mas confundido que Garavito el día del Niño.
Responder Con Cita
  #7  
Antiguo 26-11-2010
Ledian_Fdez Ledian_Fdez is offline
Miembro
 
Registrado: jun 2006
Ubicación: Ciudad Habana, Cuba
Posts: 242
Poder: 18
Ledian_Fdez Va por buen camino
Thumbs down El TRIGGER no me pincha como quiero

mightydragonlor, Lo intenete con este código, pero siempre me entra en el begin. ¿Que pudiera ser? Es desir aunque el codigo no se repita entra en el begin.

Código SQL [-]
CREATE [InsUpd_Tipo_Bodega] ON [dbo].[Tipo_Bodega]
FOR INSERT, UPDATE 

AS 

DECLARE @Codigo Char(2)
SELECT @Codigo=Codigo FROM Inserted

IF EXISTS (SELECT * FROM Tipo_Bodega WHERE Codigo=@Codigo)
  BEGIN
  RAISERROR ('No se admiten Codigos repetido. Intente con otro por favor.', 16, 1)
    ROLLBACK TRAN
  RETURN
  END

GO

Grasias de antemano,
Disculpen las molestias que pueda ocacionarles,
Pero no salgo de esto !!

SAlu2,
Ledian.
Responder Con Cita
  #8  
Antiguo 26-11-2010
Avatar de mightydragonlor
[mightydragonlor] mightydragonlor is offline
Miembro Premium
 
Registrado: feb 2007
Ubicación: Medellín-Colombia
Posts: 587
Poder: 18
mightydragonlor Va por buen camino
Código SQL [-]
CREATE [InsUpd_Tipo_Bodega] ON [dbo].[Tipo_Bodega]
FOR INSERT, UPDATE 
AS 

DECLARE @Codigo Char(2)
SELECT @Codigo=Codigo FROM Inserted

SELECT 1 FROM Tipo_Bodega WHERE Codigo=@Codigo
IF @@ROWCOUNT
  BEGIN
  RAISERROR ('No se admiten Codigos repetido. Intente con otro por favor.', 16, 1)
    ROLLBACK TRAN
  RETURN
  END

GO
Intenta con eso y me cuentas.
__________________
mas confundido que Garavito el día del Niño.
Responder Con Cita
  #9  
Antiguo 29-11-2010
Ledian_Fdez Ledian_Fdez is offline
Miembro
 
Registrado: jun 2006
Ubicación: Ciudad Habana, Cuba
Posts: 242
Poder: 18
Ledian_Fdez Va por buen camino
Arrow RAISERROR no me muestra mensaje.

Te cuento, que ahora si no me deja insertar dos códigos repetidos, solo que no me salta el mensaje
Cita:
Código SQL [-]
RAISERROR ('No se admiten Codigos repetido. Intente con otro por favor.', 16, 1)
Código SQL [-]
ALTER TRIGGER [InsUpd_Tipo_Bodega] ON [dbo].[Tipo_Bodega]
FOR INSERT, UPDATE 

AS 

DECLARE @Codigo Char(2)
SELECT @Codigo=Codigo FROM Inserted

SELECT 1 FROM Tipo_Bodega WHERE Codigo=@Codigo
IF (@@ROWCOUNT>1)
  BEGIN
    RAISERROR ('No se admiten Codigos repetido. Intente con otro por favor.', 16, 1)
    ROLLBACK TRAN
    RETURN
  END

GO

Muchas grasias ...

salu2,
Ledian.
Responder Con Cita
  #10  
Antiguo 29-11-2010
Ledian_Fdez Ledian_Fdez is offline
Miembro
 
Registrado: jun 2006
Ubicación: Ciudad Habana, Cuba
Posts: 242
Poder: 18
Ledian_Fdez Va por buen camino
Post RAISERROR no me muestra mensaje.

Como bien les habia dicho anteriormente no se por que no me lansa el mensaje de error, sin embargo no me inserta el código cuando este ya se encuantra en la tabla, lo curioso es que tengo que cerrar la tabla y volver abrirla para darme cuanta que no fue insertada pues este se ve como si se hubiera insertado normalmente.


¿Me podrian ayudar al respecto?

mil grasias ...

Salu2,
Ledian.
Responder Con Cita
  #11  
Antiguo 29-11-2010
Ledian_Fdez Ledian_Fdez is offline
Miembro
 
Registrado: jun 2006
Ubicación: Ciudad Habana, Cuba
Posts: 242
Poder: 18
Ledian_Fdez Va por buen camino
Post Problema al lanzar un RAISERROR

Hola chicos, que manera de insistir la mía, el problema es que he seguido probando y buscándole una respuesta al ¿Por qué no me lanza el RAISERROR el mensaje?

Lo curioso es que con este código si sale el mensaje:

Código SQL [-]
ALTER TRIGGER [InsUpd_TipoProducto] ON [dbo].[TipoProducto] 
FOR INSERT, UPDATE
AS

DECLARE @Codigo Char(2)
SELECT @Codigo=Codigo FROM Inserted

IF EXISTS(SELECT Codigo FROM TipoProducto WHERE Codigo=@Codigo)
  BEGIN
    RAISERROR ('No se admiten Códigos repetido. Intente con otro por favor.', 16, 1)
    ROLLBACK TRAN
    RETURN
  END
Lo malo es que con este código no hace lo que quiero pues siempre va a existir.

Cuando pongo este otro:
A
Código SQL [-]
LTER TRIGGER [InsUpd_TipoProducto] ON [dbo].[TipoProducto] 
FOR INSERT, UPDATE
AS

DECLARE @Codigo Char(2)
SELECT @Codigo=Codigo FROM Inserted 
SELECT Codigo FROM TipoProducto WHERE Codigo=@Codigo
IF (@@ROWCOUNT>1)
  BEGIN
    RAISERROR ('No se admiten Códigos repetido. Intente con otro por favor.', 16, 1)
    ROLLBACK TRAN
    RETURN
  END
No me deja repetir el código, solo que no me lanza el mensaje

¿En que podrá consistir tal hecho?

En lo único que difieren es en la linea:

Código SQL [-]
IF EXISTS(SELECT Codigo FROM TipoProducto WHERE Codigo=@Codigo)

Código SQL [-]
IF (@@ROWCOUNT>1)


En espera de su ayuda
Y como siempre mil gracias de antemano.

Salu2,
Ledian.
Responder Con Cita
  #12  
Antiguo 29-11-2010
Avatar de mightydragonlor
[mightydragonlor] mightydragonlor is offline
Miembro Premium
 
Registrado: feb 2007
Ubicación: Medellín-Colombia
Posts: 587
Poder: 18
mightydragonlor Va por buen camino
entonces usa el primero que pusiste solo que el trigger deberia estar before insert, before update.
__________________
mas confundido que Garavito el día del Niño.
Responder Con Cita
  #13  
Antiguo 29-11-2010
Avatar de ContraVeneno
ContraVeneno ContraVeneno is offline
Miembro
 
Registrado: may 2005
Ubicación: Torreón, México
Posts: 4.738
Poder: 23
ContraVeneno Va por buen camino
¿no era más sencillo ponerle un índice único al campo que no debe repetirse?
__________________

Responder Con Cita
  #14  
Antiguo 29-11-2010
Avatar de mightydragonlor
[mightydragonlor] mightydragonlor is offline
Miembro Premium
 
Registrado: feb 2007
Ubicación: Medellín-Colombia
Posts: 587
Poder: 18
mightydragonlor Va por buen camino
Cita:
Empezado por ContraVeneno Ver Mensaje
¿no era más sencillo ponerle un índice único al campo que no debe repetirse?
si, pero el quiere el mensajito
__________________
mas confundido que Garavito el día del Niño.
Responder Con Cita
  #15  
Antiguo 29-11-2010
Avatar de ContraVeneno
ContraVeneno ContraVeneno is offline
Miembro
 
Registrado: may 2005
Ubicación: Torreón, México
Posts: 4.738
Poder: 23
ContraVeneno Va por buen camino
pues sería lo mismo, ¿no?

pones el índice único y en lugar de verificar con cualquiera de las formas:

Código SQL [-]
IF EXISTS(SELECT Codigo FROM TipoProducto WHERE Codigo=@Codigo)
....
SELECT @Codigo=Codigo FROM Inserted
SELECT Codigo FROM TipoProducto WHERE Codigo=@Codigo
IF (@@ROWCOUNT>1)


con esto sería suficiente:
Código SQL [-]
If (@@Error > 0 )
Verificas si el número de error es de llave duplicada y muestras el mensaje...

__________________

Responder Con Cita
  #16  
Antiguo 01-12-2010
Ledian_Fdez Ledian_Fdez is offline
Miembro
 
Registrado: jun 2006
Ubicación: Ciudad Habana, Cuba
Posts: 242
Poder: 18
Ledian_Fdez Va por buen camino
Thumbs down

Cita:
Empezado por mightydragonlor Ver Mensaje
entonces usa el primero que pusiste solo que el trigger deberia estar before insert, before update.
El motor de base de datos es MS SQL server 2000 y no me reconoce before insert, before update
Responder Con Cita
  #17  
Antiguo 01-12-2010
Ledian_Fdez Ledian_Fdez is offline
Miembro
 
Registrado: jun 2006
Ubicación: Ciudad Habana, Cuba
Posts: 242
Poder: 18
Ledian_Fdez Va por buen camino
Exclamation

Cita:
Empezado por ContraVeneno Ver Mensaje
¿no era más sencillo ponerle un índice único al campo que no debe repetirse?
Pues comparto ese criterio con usted, pero el problema radica que ya la base de datos esta diseñada asi y la aplicacion tambien, solo que necesito hacerle unos pequeños arreglos, y no es facil a esta altura modificar cada uno de los campos.
Responder Con Cita
  #18  
Antiguo 01-12-2010
Ledian_Fdez Ledian_Fdez is offline
Miembro
 
Registrado: jun 2006
Ubicación: Ciudad Habana, Cuba
Posts: 242
Poder: 18
Ledian_Fdez Va por buen camino
Angry

Cita:
Empezado por mightydragonlor Ver Mensaje
si, pero el quiere el mensajito
No es un problema de "mensajito" como bien dices, solo es cuestión de informarle al usuario que es lo que anda mal.
Responder Con Cita
  #19  
Antiguo 31-01-2011
abelg abelg is offline
Miembro
 
Registrado: jul 2004
Posts: 50
Poder: 20
abelg Va por buen camino
Creo si no quieres que ingresen un código duplicado solo necesitas poner unique al definir tu campo.

Create table producto (
id_producto int identity not null primary key,
codigo Varchar(10) not null unique,
...
)

Asi cuando intente ingresar un codigo duplicado no dejara.
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
llamar a procedure desde otra procedure anubis Varios 23 04-03-2010 18:44:37
puntero a un procedure en un procedure como parametro fcios Varios 2 14-03-2009 03:41:22
Procedure ozegarra Firebird e Interbase 5 07-12-2007 23:04:33
Procedure MarioATamborini Firebird e Interbase 5 11-08-2005 18:46:07
¿procedure? Giniromero Firebird e Interbase 18 26-02-2004 15:52:08


La franja horaria es GMT +2. Ahora son las 15:29:32.


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