views:

163

answers:

5

I have a store procedure like this:

CREATE PROCEDURE up_action
(@id int
,@group varchar(30)=''
,@nom varchar(30)=''
,@compte varchar(30)=NULL
)
 AS
BEGIN
DECLARE @chrono int
......
select @date=date from users where compte=@compte
INSERT INTO dialog
(numappel,auteur,commentaire,etape,etapews,operant)
VALUES
(@numappel,@nomprenom,@dialogue,14,14,@nomoperateur)
SET @chrono = SCOPE_IDENTITY()   
select 'chrono'=@chrono
END

I want to call this store procedure from an application written in C# with the possibility to give the parameters separated by , (actually their values) and after that to receive eventually a record set rs from wich i can get the value of the variable like rs("chrono").

I know the possibility with creating every parameter and telling the type, the name, the value etc. But I want a method like in ASP because I have procedures with 100 parameters ...

+1  A: 

Erm if you want to make the task easier look into something like LINQ to SQL.

RichardOD
+5  A: 

Normally, with POADO (Plain Old ADO.Net) you would do something like this:

using (SqlConnection conn = new SqlConnection(myConnectionString))
using (SqlCommand cmd = conn.CreateCommand())
{
    cmd.CommandType = CommandType.StoredProcedure;
    cmd.CommandText = "up_action"
    cmd.Parameters.AddWithValue("@group", group);
    cmd.Parameters.AddWithValue("@nom", nom);
    cmd.Parameters.AddWithValue("@compte", compte);
    conn.Open();
    using (SqlDataReader rd = cmd.ExecuteReader())
    {
        if (rd.Read())
        {
            chrono = rs["chrono"];
        }
    }
}

But as Richard pointed out: you indeed better look into something like LINQ to SQL, as this wil generate a method for each stored procedure (which automatically has an argument per parameter of your stored procedure). See this link for more information.

fretje
A: 

You may also want to look at the data access application block in Enterprise Libray as this provides good patterns to follow for data access. I'd also suggest you look at your SPs again and see if you can refactor them, 100 parameters sounds pretty excessive.

Mark
A: 

I imagine this is an insert/update procedure... 100 parameters sounds like too much to me, but if this is what you need, then you might want to look at table valued parameters (SQL 2008 only):

http://msdn.microsoft.com/en-us/library/bb675163.aspx

(First off though, I'd go with the above advice and have a look at an ORM like LINQ - this'll take the heavy lifting out of the problem)

Paddy
A: 

So..the solution is:

SqlCommand sqlCommand = new SqlCommand(); sqlCommand.CommandText = strQuery; rdr = sqlCommand.ExecuteReader(); rdr.Read(); int chrono = Convert.ToInt32(rdr["chrono"])

And for 2 parameters rdr.NextResult(); rdr.Read(); int str = Convert.ToInt32(rdr["str"]);

Thank you all for your answers

Roxana
I'm not sure you're understanding it right... or maybe I'm misunderstanding you. But a parameter is what you send as input to the stored procedure (and which you add to the cmd.Parameters collection (see my answer above)). A resultset is what gets returned by the stored procedure. You only need NextResult() if there are multiple resultsets returned (which I believe is not the case with your procedure).
fretje