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

Dotnet Discussion :

création et appel d'une procédure stockée avec passage de liste de GUID en paramètre


Sujet :

Dotnet

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Décembre 2007
    Messages
    696
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Décembre 2007
    Messages : 696
    Par défaut création et appel d'une procédure stockée avec passage de liste de GUID en paramètre
    Bonjour.

    Voilà, j'ai créé une procédure stockée. Celle-ci doit prendre en paramètre une liste de Guid en principe, seulement je n'arrive à aller jusqu'au bout.

    voici mon 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
    public static void StoredProcedure_Collection_CreateProductTags(Guid ProductID, List<Guid> TagIDs)
            {
                using (LivDevisContext db = new LivDevisContext())
                {
                    db.Database.Connection.Open();
     
                    DbCommand cmd = db.Database.Connection.CreateCommand();
                    cmd.CommandText = "Collection_CreateProductTags";
                    cmd.CommandType = CommandType.StoredProcedure;
     
                    cmd.Parameters.Add(new SqlParameter { ParameterName = "@ProductID", Value = ProductID, DbType = DbType.Guid, Direction = ParameterDirection.Input });
                    cmd.Parameters.Add(new SqlParameter { ParameterName = "@TagID", Value = TagIDs, DbType = DbType.Guid, Direction = ParameterDirection.Input });
     
                    cmd.ExecuteReader();
                }
            }
    voici le début de ma procédure stockée sur sqlserver :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    ALTER PROCEDURE [dbo].[Collection_CreateProductTags] (@ProductID UNIQUEIDENTIFIER, @TagID UNIQUEIDENTIFIER)
    AS
    BEGIN
    	/*INSERT INTO [LivDevis].[dbo].[ProductTags] ([Product_ProductID], [Tag_TagID]) VALUES (@ProductID, @TagID);*/
    END
    J'espère ne pas m'être trompé d'endroit en écrivant ce topic.
    Pourriez-vous me dire comment je peux passer une liste en paramètre et faire mon INSERT au mieux svp ?
    Merci.

  2. #2
    Membre éclairé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Décembre 2007
    Messages
    696
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Décembre 2007
    Messages : 696
    Par défaut
    apparemment il serait possible de passer un XML en paramètre, mais j'ai du mal à trouver des informations récentes à ce sujet. Savez-vous quelque chose là-dessus ?

  3. #3
    Membre éclairé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Décembre 2007
    Messages
    696
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Décembre 2007
    Messages : 696
    Par défaut
    voici la procédure stockée que j'ai écris d'après des exemples vu sur le net.
    Cependant j'ai toujours du mal à créer mon xml du coté de c#.
    Je ne peux toujours pas vérifier que ce que j'ai écris est correct.

    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
    36
    37
    38
    39
    40
    41
    42
    43
    USE [LivDevis]
    GO
    /****** Object:  StoredProcedure [dbo].[Collection_CreateProductTags]    Script Date: 21/02/2013 15:42:59 ******/
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO
    -- =============================================
    -- Author:      Maxime AUBRY
    -- Create date: 21/02/2013 14:48:41
    -- Description: This stored procedure is called to create a collection of Product / Tag.
    -- =============================================
    ALTER PROCEDURE [dbo].[Collection_CreateProductTags] (@ProductID UNIQUEIDENTIFIER, @TagIDs XML)
    AS
    BEGIN
     
    	/* Declaring the cursor */
    	DECLARE @TagID UNIQUEIDENTIFIER
    	DECLARE TagIDs CURSOR FOR
     
    	SELECT x.y.value('.','UNIQUEIDENTIFIER') AS TagID
        FROM @TagIDs.nodes('/TagIDs/TagID') AS x ( y )
     
    	/* Opening the cursor */
    	OPEN TagIDs;
     
    	/* Reading the first cursor */
    	FETCH NEXT FROM TagIDs
    	INTO @TagID
     
    	WHILE @@FETCH_STATUS = 0
    	BEGIN
    		INSERT INTO [LivDevis].[dbo].[ProductTags] ([Product_ProductID], [Tag_TagID]) VALUES (@ProductID, @TagID);
     
    		/* Reading the next cursor */
    		FETCH NEXT FROM TagIDs
    		INTO @TagID
    	END
     
    	/* Closing the cursor */
    	CLOSE TagIDs;
    	DEALLOCATE TagIDs;
    END
    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
    public static void StoredProcedure_Collection_CreateProductTags(Guid ProductID, List<Guid> TagIDs)
            {
                using (LivDevisContext db = new LivDevisContext())
                {
                    db.Database.Connection.Open();
     
                    DbCommand cmd = db.Database.Connection.CreateCommand();
                    cmd.CommandText = "Collection_CreateProductTags";
                    cmd.CommandType = CommandType.StoredProcedure;
     
                    XElement Tags = new XElement("TagIDs");
                    foreach (Guid TagID in TagIDs)
                    {
                        XElement Tag = new XElement("TagID");
                        Tag.Value = TagID.ToString();
                        Tags.
                    }
     
                    cmd.Parameters.Add(new SqlParameter { ParameterName = "@ProductID", Value = ProductID, DbType = DbType.Guid, Direction = ParameterDirection.Input });
                    cmd.Parameters.Add(new SqlParameter { ParameterName = "@TagIDs", Value = Tags, DbType = DbType.Xml, Direction = ParameterDirection.Input });
     
                    cmd.ExecuteReader();
                }
            }

Discussions similaires

  1. [Débutant] Appel d'une procédure stockée avec paramètre en output
    Par Malainet dans le forum Linq
    Réponses: 5
    Dernier message: 11/02/2013, 16h26
  2. [Débutant] Appel d'une procédure stockée avec paramètres
    Par Bakkach dans le forum VB.NET
    Réponses: 6
    Dernier message: 09/10/2012, 16h41
  3. Appel d'une procédure stockée avec c#
    Par ing_ensi84 dans le forum C#
    Réponses: 3
    Dernier message: 05/01/2012, 10h28
  4. Appel d'une procédure stockée avec un curseur
    Par lapanne dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 26/12/2006, 16h24
  5. Appel d'une procédure stockée par un vbscript
    Par NicoNours dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 08/10/2004, 13h53

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