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

Sybase Discussion :

[ASE][T-SQL] PB récupération d'une date


Sujet :

Sybase

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 95
    Par défaut [ASE][T-SQL] PB récupération d'une date
    Bonjour, voici mon problème :

    J'ai une base de données SYBASE contenant deux champs :
    un champs "datechangement" au format DATE
    un champs "heure_creation" au formate TIME

    Lorsque je récupère "datechangement" j'obtiens bien la date contenue dans la base mais aussi une heure "bidon" qui m'embête beaucoup.
    En clair dans la base j'ai : Jan 2 2007
    et à l'affichage j'ai : Jan 2 2007 12:00AM


    Pour l'heure_creation dans la base si je fais un select j'obtiens bien une heure mais en PERL quand je fais le SELECT heure_creation j'obtiens l'heure ET une date "bidon"
    En clair dans la base j'ai : 1:04PM
    et à l'affichage j'ai : Jan 1 1900 1:04PM

    J'ai essayé avec timelocal() mais ça ne marche pas..
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    #affichage de la date
    ref[0] : Nov 18 2006 12:00AM
    #resultat avec timelocal
    sec=>0 min->0 heures->1 jour->1 mois->0 an->70
    Merci d'avance.

    Codes sources :

    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
    #!/soft/perl/bin/perl -I/data/web/cmia/lib 
     
    use strict;
    use warnings;
    use diagnostics;			# display better warning information
    use CGI::Carp qw(fatalsToBrowser);	# display errors to browser
    use CGI qw/:standard/;
    use CGI;
    use Time::Local; 
     
    use DB::DB_documentation;
    use Data::Dumper;
     
    # Connect Base
     
    my $SYBASE_BASE='documentation';
    my $connection = DB_documentation::connect($SYBASE_BASE);
     
    my $requete = "SELECT datechangement FROM FormChangementProd";
    my $sth = $connection->prepare($requete);
    	$sth->execute();		
     
    my @ref = $sth->fetchrow_array; 
     
    my ($secondes, $minutes, $heures, $jour_mois, $mois, $annee, $jour_semaine, $jour_calendaire, $heure_ete)=localtime($ref[0]);
     
    print	header,
    	start_html(
    			-style		=> {	'src'	=> "a"},
    			-script		=> {	'src'	=> "b.js"},
    			-author		=> '*',
    			-meta		=> {	'Keywords'	=> "",
    						'Copyright'	=> '*'},
    			-title		=> "titre",
    		),"<br>ref[0] : ".$ref[0],
    		"<br>","sec->".$secondes," min->".$minutes," heures->".$heures," jour->".$jour_mois," mois->".$mois," an->".$annee,
    		 #$jour_semaine, $jour_calendaire."-", $heure_ete."-";
    	end_html();

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 307
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 307
    Par défaut
    Pour des raisons de simplification DBD::Sybase convertit les types DATE et TIME en DATETIME au moment du fetch.

    Il y a plusieurs solutions. Soit au moment du SELECT, avec un convert(varchar, champ_date, 108), soit dans le code perl on peut simplement dire que la valeur 1 janvier 1900 est "invalide" et qu'il faut l'ignorer.

    Michael

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 95
    Par défaut
    Merci ça fonctionne enfin !

    Mais je ne trouve pas cela trés "propre"


    En effectuant des recherches je suis tombé sur bind_param.


    $sth->bind_param( 11,$rowdata[10],SQL_DATE);

    J'ai pas vraiment compris l'utilité ni comment l'utiliser mais ne serait-ce pas "la solution" ?

  4. #4
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 307
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 307
    Par défaut
    Le bind_param() est utilisé pour le passage de paramètres pour remplacer les "?" dans une requète. Cela n'est pas utile lors d'un "fetch".

    J'accepte volontier un patch pour DBD::Sybase pour améliorer le comportement :-)

    Michael (auteur de DBD::Sybase)

  5. #5
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 228
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 228
    Billets dans le blog
    25
    Par défaut
    Sauf erreur, en 15 devraient apparaître les types DATE et TIME
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

  6. #6
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 307
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 307
    Par défaut
    En effet (et ces nouveaux types sont déjà dispo en 12.5.3).

    La problématique est que l'appli cliente n'est pas toujours codée pour différencier ces types, et OpenClient va convertir les DATE et TIME en DATETIME dans ce cas.

    Michael

Discussions similaires

  1. Réponses: 9
    Dernier message: 01/03/2013, 10h22
  2. Réponses: 2
    Dernier message: 08/04/2008, 19h11
  3. Réponses: 1
    Dernier message: 12/05/2006, 17h07
  4. [VB6]récupération d'une date à partir d'une calendrier
    Par fahmichebaane dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 03/04/2006, 16h40
  5. [Sql Server] Fusion d'une date et d'une heure
    Par Invité dans le forum Langage SQL
    Réponses: 4
    Dernier message: 20/07/2005, 14h55

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