IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

ASP.NET Discussion :

[3.5 + ADO.net] Récup Output Parameter


Sujet :

ASP.NET

  1. #1
    CUCARACHA
    Invité(e)
    Par défaut [3.5 + ADO.net] Récup Output Parameter
    Salut,

    J'ai créé une Proc qui permet de paginer le jeu d'enregistrement de sortie.
    Pour gérer mes boutons de pagination, j'ai besoin du nombre maxi de lignes.
    Lorsque j'implémente la proc dans mon objet sqlCommand, je récupère null dans @Rows alors qu'en exécution pas à pas de la proc, j'ai bien une valeur.

    Quelqu'un pourrait-il m'aider ?

    Voici la proc et le code qui l'exécute

    Proc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
     
    ALTER PROCEDURE dbo.SITM_SA_Users_And_Roles_List
    (
        @intPremiereLigne int,
        @intNbrLignesPage int,
        @Rows int=0 OUTPUT
    )
     
    as
    	SELECT 
    		@Rows = count(aspnet_Users.UserId)
    	FROM         
    		aspnet_Users INNER JOIN
    		aspnet_UsersInRoles ON aspnet_Users.UserId = aspnet_UsersInRoles.UserId INNER JOIN
    		aspnet_Roles ON aspnet_UsersInRoles.RoleId = aspnet_Roles.RoleId;
     
    With mCte (RowNumber, idUser, txtNom, idRole,txtRole)
    As
    (
    	SELECT 
    		Row_Number() over (order by aspnet_Users.UserName asc) as RowNumber,
    		aspnet_Users.UserId as idUser, 
    		aspnet_Users.UserName as txtNom, 
    		aspnet_Roles.RoleId as idRole, 
    		aspnet_Roles.RoleName as txtRole
    	FROM         
    		aspnet_Users INNER JOIN
    		aspnet_UsersInRoles ON aspnet_Users.UserId = aspnet_UsersInRoles.UserId INNER JOIN
    		aspnet_Roles ON aspnet_UsersInRoles.RoleId = aspnet_Roles.RoleId
    )
    Select    *
    From mCte C
    Where    RowNumber Between @intPremiereLigne and (@intPremiereLigne + @intNbrLignesPage -1)
     
    RETURN
    Code C#
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
     
                int intFirstRow;
                int intRowsPerPage;
     
                intFirstRow = Int32.Parse(hidFirstRow.Value);
                intRowsPerPage = Int32.Parse(hidRowsPerPage.Value);
     
                SqlConnection oConn = new SqlConnection();
                SqlCommand oCmd = new SqlCommand();
                SqlDataReader oDR;
                string strConnString = ConfigurationManager.ConnectionStrings["SITMConnectionString"].ConnectionString;
                oConn.ConnectionString = strConnString;
                oConn.Open();
                oCmd.Connection = oConn;
                oCmd.CommandType = CommandType.StoredProcedure;
                oCmd.CommandText = "SITM_SA_Users_And_Roles_List";
                oCmd.Parameters.Add(new SqlParameter("@intPremiereLigne", intFirstRow));
                oCmd.Parameters.Add(new SqlParameter("@intNbrLignesPage", intRowsPerPage));
                SqlParameter oRows = new SqlParameter("@Rows", SqlDbType.Int);
                oRows.Direction = ParameterDirection.Output;
                oCmd.Parameters.Add(oRows);
     
                oDR = oCmd.ExecuteReader();
     
                hidRows.Value = oCmd.Parameters["@Rows"].Value.ToString();
                rptList.DataSource = oDR;
                rptList.DataBind();
     
                oConn.Close();
    Notez que j'ai aussi essayé avec la ReturnValue j'ai null aussi. Peut-être faut-il jouer sur le behavior du datareader mais je n'ai pas réussi...

    D'avance merci pour votre aide.

    Laurent

  2. #2
    CUCARACHA
    Invité(e)
    Par défaut Arf ... Trouvé
    Salut,

    J'ai trouvé, les paramètres de sortie ne sont disponibles qu'après fermeture du DR.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
                oDR = oCmd.ExecuteReader();
                rptList.DataSource = oDR;
                rptList.DataBind();
                oDR.Close();
                hidRows.Value = oCmd.Parameters["@Rows"].Value.ToString();
                oConn.Close();
    Sorry

    ++

    Laurent

  3. #3
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Par défaut
    Si c'est résolu ->

    Merci.
    Besoin d'un MessageBox amélioré ? InformationBox pour .NET 1.1, 2.0, 3.0, 3.5, 4.0 sous license Apache 2.0.

    Bonnes pratiques pour les accès aux données
    Débogage efficace en .NET
    LINQ to Objects : l'envers du décor

    Mon profil LinkedIn - MCT - MCPD WinForms - MCTS Applications Distribuées - MCTS WCF - MCTS WCF 4.0 - MCTS SQL Server 2008, Database Development - Mon blog - Twitter

Discussions similaires

  1. [vb.net][vbexpress] erreur output parameter stored procedure
    Par graphicsxp dans le forum Windows Forms
    Réponses: 14
    Dernier message: 07/12/2005, 18h24
  2. [VB.NET] [ADO.NET] Adapter, TableMapping et DataSet xsd
    Par neo.51 dans le forum Accès aux données
    Réponses: 14
    Dernier message: 23/09/2004, 16h52
  3. [VB.NET] [ADO.NET] DataAdapter et concaténation
    Par master56 dans le forum Accès aux données
    Réponses: 3
    Dernier message: 04/06/2004, 13h25
  4. Réponses: 5
    Dernier message: 22/12/2003, 14h18
  5. [IB v7.1][C#][ADO.NET] Démarrer avec IB 71
    Par BoeufBrocoli dans le forum InterBase
    Réponses: 14
    Dernier message: 05/08/2003, 12h25

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo