Retroceder   Foros del Web > Programación para sitios web > .NET

Respuesta
 
Herramientas Desplegado
Antiguo 24-feb-2005, 05:42   #1 (permalink)
arcus está en el buen camino
 
Fecha de Ingreso: agosto-2003
Ubicación: Viña del mar
Mensajes: 280
q onda con el parametro @return_value?

saludos:

en vez de agregar`parametros , los recato del procedimiento con
SqlCommandBuilder.DeriveParameters(comandoProc)
donde comandoProc es un sqlcommand,pero simepre rescate en el index 0 el parametro @return_value,pero el el procedimiento no tiene parametros,obviamente no rescata nada,pero si existiera por ejemplo el prametro @nombre, al rescatar, siempre en el 0 pone el @return_value y despues en el indice 1 el @nombre,,,
para que sirve el @return_value, tendre problemas si lo borro?,,ya q lo e borrado y al parecer todo sin problemas o lo otro es comenzar a trabajar con los indices de 1,,,,,

gracias
arcus está desconectado   Responder Citando
Antiguo 24-feb-2005, 08:35   #2 (permalink)
Moderador
RootK llegará a ser famoso muy prontoRootK llegará a ser famoso muy pronto
 
Avatar de RootK
 
Fecha de Ingreso: noviembre-2002
Ubicación: México D.F
Mensajes: 7.527
Enviar un mensaje por MSN a RootK
Cita:
para que sirve el @return_value
por lo regular se ocupara para regresar algun valor de tu SP, es decir, haces algun tipo de comparacion interna y dependiendo del resultado regresaras lo que necesitas.

Claro que todo depende de que estes haciendo.

por ejemplo, tienes un SP como ésto:

Cita:
CREATE PROCEDURE dbo.SelectCustomers
(
@EmployeeID int
)
AS
declare @i INT

set @i =
(
SELECT count(*) FROM Customers INNER JOIN Orders
ON Customers.CustomerID = Orders.CustomerID
WHERE (Orders.EmployeeID = @EmployeeID)
)

IF @i > 1
--REGRESO ALGUN VALOR
return 12
ELSE
--OTRO VALOR
return 23

GO
Y ya por código haces un executenonquery para obtener despues el valor:

ejemplo:
Cita:
...
...
Dim paramReturn As SqlParameter

paramReturn = myCommand.Parameters.Add("@RETURN_VALUE", SqlDbType.Int)
paramReturn.Direction = ParameterDirection.ReturnValue

Dim param As New SqlParameter("@EmployeeID", SqlDbType.Int)
param.Value = 30
myCommand.Parameters.Add(param)

Dim intResult As Integer

myConnection.Open()
myCommand.ExecuteNonQuery()
'aqui recibo el valor que regresa mi SP
intResult = myCommand.Parameters("@RETURN_VALUE").Value
myConnection.Close()

Response.Write("resultado = " & intResult)
Es un ejemplo muy general, solo espero que lo hayas entendido.

Salu2
__________________
Nadie roba nada ya que en la vida todo se paga . . .
RootK está desconectado   Responder Citando
Respuesta
No hay votos aún.


Herramientas
Desplegado

Normas de Publicación
No puedes crear nuevos temas
No puedes responder temas
No puedes subir archivos adjuntos
No puedes editar tus mensajes

BB code is Activado
Caritas están Activado
[IMG] está Activado
Código HTML está Desactivado


La Zona horaria es GMT -6. Ahora son las 16:02.


Message Board Statistics

LinkBacks Enabled by vBSEO 3.1.0

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93