10
mars
2009
[Sql Serveur 2008] Le type HierarchyID et les datasets typés
mars
2009
Un article de nico-pyright(c)
Pas de commentaires
J’ai essayé d’exécuter une procédure stockée qui avait en paramètre un type HierarchyID.
Un truc du genre :
ALTER PROCEDURE [Ma_proc_stoc]
(
@guid uniqueidentifier,
@type int,
@parent HIERARCHYID
)
AS
(
@guid uniqueidentifier,
@type int,
@parent HIERARCHYID
)
AS
Et je me suis retrouvé avec cette erreur :
La propriété UdtTypeName doit être définie pour les paramètres UDT
J’ai essayé de voir où on pouvait mettre ce fameux paramètre dans mon dataset, mais j’ai été incapable de le trouver.
Si vous avez le même problème que moi, vous pouvez vous en sortir avec le classique objet IDbCommand. Il faudra utiliser le type SqlDbType.Udt et mettre le paramètre UdtTypeName à HierarchyId.
DbProviderFactory factory = DbProviderFactories.GetFactory(ProviderName);
using (IDbConnection connection = factory.CreateConnection())
{
connection.ConnectionString = ConnectionString;
connection.Open();
using (IDbCommand command = factory.CreateCommand())
{
command.Connection = connection;
SqlParameter typeParameter = new SqlParameter(« @type », SqlDbType.Int) { Value = type };
SqlParameter parentParameter = new SqlParameter(« @parent », SqlDbType.Udt) { UdtTypeName = « HierarchyId », Value = level};
command.Parameters.Add(guidParameter);
command.Parameters.Add(typeParameter );
command.Parameters.Add(parentParameter );
command.CommandText = « Ma_proc_stoc »;
command.ExecuteNonQuery();
}
}
using (IDbConnection connection = factory.CreateConnection())
{
connection.ConnectionString = ConnectionString;
connection.Open();
using (IDbCommand command = factory.CreateCommand())
{
command.Connection = connection;
SqlParameter guidParameter = new SqlParameter(« @guid », SqlDbType.UniqueIdentifier) { Value = Guid.NewGuid()};
SqlParameter typeParameter = new SqlParameter(« @type », SqlDbType.Int) { Value = type };
SqlParameter parentParameter = new SqlParameter(« @parent », SqlDbType.Udt) { UdtTypeName = « HierarchyId », Value = level};
command.Parameters.Add(guidParameter);
command.Parameters.Add(typeParameter );
command.Parameters.Add(parentParameter );
command.CommandType =
CommandType.StoredProcedure;command.CommandText = « Ma_proc_stoc »;
command.ExecuteNonQuery();
}
}
Si vous connaissez un moyen pour paramétrer le dataset typés, je suis à l’écoute
Commentaires récents
- [Tests] Arrange Act Assert, une traduction ? dans
- [UnitTest][C#] Tester une méthode privée dans
- Récupérer une valeur d’un contrôle depuis une autre Form / inclusions croisées et déclaration anticipée dans
- Tutoriel : Utiliser la ListBox et l’Isolated Storage dans vos applications Windows Phone 7 avec Silverlight dans
- Tutoriel : Utiliser la ListBox et l’Isolated Storage dans vos applications Windows Phone 7 avec Silverlight dans
Archives
- janvier 2013
- avril 2012
- janvier 2012
- juin 2011
- janvier 2011
- décembre 2010
- novembre 2010
- septembre 2010
- juin 2010
- mars 2010
- février 2010
- janvier 2010
- décembre 2009
- novembre 2009
- octobre 2009
- septembre 2009
- août 2009
- juillet 2009
- mai 2009
- avril 2009
- mars 2009
- janvier 2009
- décembre 2008
- novembre 2008
- octobre 2008
- septembre 2008
- août 2008
- juillet 2008
- juin 2008
- mai 2008
- avril 2008
- mars 2008
- février 2008
- janvier 2008
- décembre 2007
- novembre 2007
- octobre 2007
- septembre 2007
- août 2007
- juillet 2007
- juin 2007
- mai 2007