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

C# Discussion :

DataTable et DateTime object


Sujet :

C#

  1. #1
    Membre actif Avatar de Mast3rMind
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    226
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2006
    Messages : 226
    Points : 219
    Points
    219
    Par défaut DataTable et DateTime object
    Bonjour,

    Je désire faire un select sur une dataTable en triant sur un champ de type DateTime. Voici ce que je fais en ce moment:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    DateTime dateTest = new DateTime(2008, 03, 27);
     
    string sortOrder = "BillingDate ASC";
    DataRow[] foundRows = dataTable.Select("CustomerNumber = '" + strCustomerNumber + "' AND BillingDate > '" + dateTest + "'", sortOrder);
    Le problème est que je suis dépendant de la culture... Comment ne pas dépendre de la culture pour que ça fonctionne toujours?

    Aussi, je dois ramener mon BillingDate à minuit pour faire la comparaison des dates uniquement sur la date sans les heures... je sais le faire en Oracle, mais comment le faire sur une dataTable?

    En Oracle:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "TO_DATE(TO_CHAR(BillingDate ,'DD-MM-YYYY'),'DD-MM-YYYY') >= TO_DATE('" + dateTest.ToString("dd-MM-yyyy") + "', 'DD-MM-YYYY')"
    Merci pour votre aide!

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    Utilise des paramètres pour ta requête

    EDIT: Horreur ! Avec DataTable.Select tu ne peux pas spécifier de paramètres... C'est là que les datasets montrent leurs limites

  3. #3
    Membre actif Avatar de Mast3rMind
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    226
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2006
    Messages : 226
    Points : 219
    Points
    219
    Par défaut
    Oui j'avais pensé aux paramètres mais comme toi j'ai eu la même réaction en découvrant que ça n'existait pas... Horreur!

    Help plz!

  4. #4
    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
    Points : 6 334
    Points
    6 334
    Par défaut
    Citation Envoyé par Mast3rMind Voir le message
    Oui j'avais pensé aux paramètres mais comme toi j'ai eu la même réaction en découvrant que ça n'existait pas... Horreur!

    Help plz!
    T'as essayé ça ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DataRow[] foundRows = dataTable.Select("CustomerNumber = '" + strCustomerNumber + "' AND BillingDate > #" + dateTest + "#", sortOrder);

  5. #5
    Membre émérite Avatar de Guulh
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    2 160
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2007
    Messages : 2 160
    Points : 2 925
    Points
    2 925
    Par défaut
    J'avais eu le souci aussi, dans les expressions de filtre des DataView. ce que j'en retiens : ce "langage" simili-sql utilisé par les DataTable / DataViews n'est pas super documenté ni flexible, et il me semble bien qu'il ne comprend que les dates ToStringuées au format US.

  6. #6
    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
    Points : 6 334
    Points
    6 334
    Par défaut
    Si tu travailles en 3.5, ceci pourrait t'intéresser : http://cs.rthand.com/blogs/blog_with...01/15/284.aspx

    EDIT : En fait tu peux aussi utiliser LINQ to DataSet.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 2
    Dernier message: 22/09/2011, 08h58
  2. Réponses: 2
    Dernier message: 20/01/2011, 22h56
  3. DataGridView : liste object et DataTable
    Par cedricg1976 dans le forum Windows Forms
    Réponses: 2
    Dernier message: 08/07/2009, 22h20
  4. [VB.NET] définir format colonne datetime d'un datatable
    Par HULK dans le forum Windows Forms
    Réponses: 2
    Dernier message: 06/12/2005, 16h58
  5. [C#] DateTime et object
    Par liliprog dans le forum ASP.NET
    Réponses: 9
    Dernier message: 06/09/2005, 18h13

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