Soyez le premier à donner votre avis sur cette source.
Snippet vu 8 431 fois - Téléchargée 16 fois
using System; using System.Data; using System.Configuration; using System.Linq; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.HtmlControls; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Xml.Linq; using System.Collections.Generic; using System.Reflection; namespace Tests { /// <sumary> /// Type permettant de spécifier le sens du tri /// <sumary> public enum OrderType : int { Asc = 1, Desc = -1 } /// <sumary> /// Interface à implémenter pour la gestion de collections triables /// <sumary> public interface IOrderableCollection { /// <sumary> /// Obtient ou définit la propriété sur laquelle la collection est triée /// <sumary> PropertyInfo PropertyOrder { get; set; } /// <sumary> /// Obtient ou définit le sens du tri /// <sumary> OrderType OrderType { get; set; } /// <sumary> /// Tri la liste en fonction du nom du champ et du sens de tri /// <sumary> void Sort(string fieldName, OrderType orderType); } /// <sumary> /// Exemple d'implémentation sur une collection generics /// <sumary> public class OrderableList<T> : List<T>, IOrderableCollection { public PropertyInfo PropertyOrder { get; set; } public OrderType OrderType { get; set; } public void Sort(string fieldName, OrderType orderType) { this.OrderType = orderType; this.PropertyOrder = typeof(T).GetProperty(fieldName); if (this.PropertyOrder != null) this.Sort(Compare); } private int Compare(T t1, T t2) { object obj1 = this.PropertyOrder.GetValue(t1, null); object obj2 = this.PropertyOrder.GetValue(t2, null); IComparable obj1Comparable = obj1 as IComparable; if (obj1Comparable != null) return obj1Comparable.CompareTo(obj2) * (int)this.OrderType; return 0; } } }
J'ai posté une requette pas trop identique mais je crois que vous etes déjà sur la piste de m'aider. Alors sans hésiter je pose mon blème.
Ma tâche dans un job est de créer une classe (ou dll) LINQ pouvant se connecter à n'importe quel BD est pouvant accepter n'importe quel requette... Voyez vous la gravité de la choise !
J'ai eu à utiliser déjà ExecuteQuery<T>(requette); Mais comme vous savez T est le type d'une table que l'on connait pas en avance...
SVP, j'ai besoin de vous tous, les gars, mettez encore vos talent de code en oeuvre !!!
> Bon prog !
J'ai fait un peut le même genre de source il n'y a pas longtemps :
http://www.aspfr.com/codes/ICOMPARER-GENERIQUE-REFLEXION_46356.aspx
Et il me semble que pour récupérer un champs (fieldname) c'est getField et pas GetProperty, après c'est peut-être/sûrement se que tu voulait faire?!
Aurait plutôt sa place dans les snippets ou, si un peu plus étoffé, dans les tutos...
Vous n'êtes pas encore membre ?
inscrivez-vous, c'est gratuit et ça prend moins d'une minute !
Les membres obtiennent plus de réponses que les utilisateurs anonymes.
Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.
Le fait d'être membre vous permet d'avoir des options supplémentaires.