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

MS SQL Server Discussion :

Adding a value to a 'datetime' column caused overflow.


Sujet :

MS SQL Server

  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    616
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Luxembourg

    Informations forums :
    Inscription : Mars 2007
    Messages : 616
    Points : 556
    Points
    556
    Par défaut Adding a value to a 'datetime' column caused overflow.
    Bonjour,

    Je ne comprends pas pourquoi j'ai cette erreur.
    Adding a value to a 'datetime' column caused overflow.
    Je l'obtiens lorsque j'exécute la première requête (en décommentant la ligne avec DATEADD), alors que le lot de deux instructions s'exécutent parfaitement.
    J'ai des '9999-12-31' dans ODS_DAT_FIN_VAL mais la sous-requête ne ramène jamais ces lignes là.

    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
    SELECT 
    	t1.UC03_C_UC			UC03_C_UC
    	,t1.UC03_D_COT			UC03_D_COT
    	,t1.UC03_M_COT_1		UC03_M_COT_1
    	,t1.UC03_NO_GRP_COTA	UC03_NO_GRP_COTA
    	,t2.ODS_DAT_FIN_VAL		ODS_DAT_DEB_VAL 
    --	,DATEADD(dd, 1, t2.ODS_DAT_FIN_VAL)		ODS_DAT_DEB_VAL 
    	,t1.ODS_DAT_FIN_VAL		ODS_DAT_FIN_VAL
    	,'Y'	SWI_MDF	
    into #tmp
    FROM #uctb03 t1
    INNER JOIN (
    	SELECT t1.* 
    	--into #tmp
    	FROM #uctb03 t1
    	LEFT JOIN #uctb03 t2
    		ON	t1.UC03_C_UC = t2.UC03_C_UC
    		AND t1.UC03_NO_GRP_COTA	= t2.UC03_NO_GRP_COTA
    		AND t1.UC03_D_COT = t2.UC03_D_COT
    		AND t2.ODS_DAT_FIN_VAL = '99991231'
    	WHERE t2.UC03_C_UC is null
    ) t2
    	ON	t1.UC03_C_UC = t2.UC03_C_UC
    	AND t1.UC03_NO_GRP_COTA	= t2.UC03_NO_GRP_COTA
    	AND t1.UC03_D_COT > t2.UC03_D_COT
    	AND t2.ODS_DAT_FIN_VAL BETWEEN DATEADD(dd, -1, t1.ODS_DAT_DEB_VAL) AND DATEADD(dd, -1, t1.ODS_DAT_FIN_VAL)
     
    update #tmp
    set ODS_DAT_DEB_VAL = dateadd(dd,1,ODS_DAT_DEB_VAL)
    Je ne comprends pas.
    Si cette erreur est produite lors de l'exécution dans ce cas là la sous requête doit ramener des 9999-12-31, ce qui n'est pas le cas.
    Si cette erreur est produite lors de la compilation, elle doit être également provoquée lorsqu'on demande le plan d'exécution, ce n'est pas ne cas non plus. Le plan d'exécution s'affiche bel et bien.

    Alors, qqun a des explications? Que faire?

  2. #2
    Membre confirmé Avatar de agemis31
    Profil pro
    DBA
    Inscrit en
    Octobre 2007
    Messages
    399
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : DBA

    Informations forums :
    Inscription : Octobre 2007
    Messages : 399
    Points : 478
    Points
    478
    Par défaut
    Bonjour,

    Je n'ai pas tout compris au problème de sous requêtes, mais '99991231 23:59:59.997' est la valeur maxi de DATETIME.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    --aille
    SELECT DATEADD(day, 1, '99991231')
    @+

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    616
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Luxembourg

    Informations forums :
    Inscription : Mars 2007
    Messages : 616
    Points : 556
    Points
    556
    Par défaut
    Citation Envoyé par agemis31 Voir le message
    Bonjour,

    Je n'ai pas tout compris au problème de sous requêtes, mais '99991231 23:59:59.997' est la valeur maxi de DATETIME.
    @+
    Oui, je sais. Ce que je voulais dire c'est que ca
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    	SELECT t1.* 
    	FROM #uctb03 t1
    	LEFT JOIN #uctb03 t2
    		ON	t1.UC03_C_UC = t2.UC03_C_UC
    		AND t1.UC03_NO_GRP_COTA	= t2.UC03_NO_GRP_COTA
    		AND t1.UC03_D_COT = t2.UC03_D_COT
    		AND t2.ODS_DAT_FIN_VAL = '99991231'
    	WHERE t2.UC03_C_UC IS NULL
    ne ramène pas de lignes avec t1.ODS_DAT_FIN_VAL = '99991231'

    Donc comme il n'y a pas de '99991231' on peut rajouter 1 jour.

  4. #4
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Votre requête fonctionne parce que SQL Server est gentil (si si ) :
    Il convertit implicitement la valeur chaîne '99991231' en date avec les heures/minutes/secondes/millisecondes à 0.

    Donc si vous n'avez pas de date dans votre table dont une représentation de la valeur serait 31/12/2009 00:00:00.000, votre requête ne ramène pas de lignes.

    Donc comme il n'y a pas de '99991231' on peut rajouter 1 jour.
    Là je n'ai pas compris

  5. #5
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    616
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Luxembourg

    Informations forums :
    Inscription : Mars 2007
    Messages : 616
    Points : 556
    Points
    556
    Par défaut
    Citation Envoyé par elsuket Voir le message
    Bonjour,

    Là je n'ai pas compris
    Si je fais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    	SELECT t1.* 
    INTO #tmp
    	FROM #uctb03 t1
    	LEFT JOIN #uctb03 t2
    		ON	t1.UC03_C_UC = t2.UC03_C_UC
    		AND t1.UC03_NO_GRP_COTA	= t2.UC03_NO_GRP_COTA
    		AND t1.UC03_D_COT = t2.UC03_D_COT
    		AND t2.ODS_DAT_FIN_VAL = '99991231'
    	WHERE t2.UC03_C_UC IS NULL
     
    -- pas d'ereur
    SELECT *, DATEADD(dd, 1, ODS_DAT_FIN_VAL) FROM #tmp
    Le deuxième SELECT ne provoque pas d'erreur par ce que le premier ne contient pas de date '9999-12-31'

Discussions similaires

  1. Unable to convert MySQL date/time value to System.DateTime
    Par mvc_dev dans le forum ASP.NET MVC
    Réponses: 2
    Dernier message: 16/08/2012, 17h05
  2. Réponses: 2
    Dernier message: 18/04/2012, 16h34
  3. Réponses: 0
    Dernier message: 20/05/2011, 16h18
  4. Adding a value to a 'datetime' column caused overflow.
    Par Griswold dans le forum Développement
    Réponses: 1
    Dernier message: 17/09/2010, 15h32
  5. ORA-01401 : inserted value too large for column
    Par Mattgic dans le forum Oracle
    Réponses: 5
    Dernier message: 25/05/2010, 10h18

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