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 Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 05-11-2015
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 Help Con Este Procedure`

Hola amigos tengo este procedimiento almacenado


Código SQL [-]
ALTER PROCEDURE COMPARE

AS

DECLARE @X INT
DECLARE @B INT
SET @B = 20

SELECT TOP 1 @X=IDMOVIMIENTO FROM MOVIMIENTO ORDER BY IDMOVIMIENTO DESC

IF @X>@B

PRINT @X + ' ES MAYOR QUE ' + @B

cuando lo ejecuto

Código SQL [-]
EXEC COMPARE

me lanza este error Conversion failed when converting the varchar value ' ES MAYOR QUE ' to data type int.


Grasias de antemano
Saludos,
Responder Con Cita
  #2  
Antiguo 05-11-2015
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
No conozco SQL Server pero supongo que la concatenación de cadenas no se hace con el operador +. En tu expresión:

Código:
PRINT @X + ' ES MAYOR QUE ' + @B
seguramente intenta convertir la cadena a entero para acoplarse a los otros parámetros. Busca a ver si hay una función CONCAT.

// Saludos
Responder Con Cita
  #3  
Antiguo 05-11-2015
Avatar de fjcg02
[fjcg02] fjcg02 is offline
Miembro Premium
 
Registrado: dic 2003
Ubicación: Zamudio
Posts: 1.408
Poder: 22
fjcg02 Va camino a la fama
Hola

Dudo si un procedimiento puede hacer un print y que se vea algo...

Por otro lado, print sólo puede usarse con strings, aunque si pone PRINT @X siendo @X un entero, creo que hace la conversión automática.

Si quieres hacer lo que muestras, debes hacer un cast de los enteros.

PRINT cast(@X as varchar(20))+' HOLAKEASE '+cast(@B as varchar(20))

Saludos
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino -
Responder Con Cita
  #4  
Antiguo 06-11-2015
Avatar de Osorio
Osorio Osorio is offline
Miembro
 
Registrado: may 2003
Ubicación: Colombia
Posts: 251
Poder: 21
Osorio Va por buen camino
Si lo que quieres es enviar un mensaje de error es mejor que veas:

RAISERROR

Ejemplo:

RAISERROR('esto es una prueba',16,217)


Si lo que quieres es indicar un estado o "informar" algo a tu aplicacion que consume el procedimiento almacenado, entonces puedes utilizar un parametro de salida OUTPUT.

Puedes darle un vistazo a este enlace:
https://technet.microsoft.com/es-es/...ql.105%29.aspx
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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
Una mano con este procedure Ledian_Fdez OOP 10 01-09-2011 17:34:32
llamar a procedure desde otra procedure anubis Varios 23 04-03-2010 19:44:37
puntero a un procedure en un procedure como parametro fcios Varios 2 14-03-2009 04:41:22
Enlazar con base de datos este donde este 4-0 C++ Builder 5 12-01-2007 21:33:00
como hago este stored procedure edy_aca Firebird e Interbase 2 13-01-2005 17:32:26


La franja horaria es GMT +2. Ahora son las 15:01:24.


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