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 :

Quelqu'un peut m'expliquer ROUND


Sujet :

MS SQL Server

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Février 2004
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2004
    Messages : 62
    Points : 43
    Points
    43
    Par défaut Quelqu'un peut m'expliquer ROUND
    SELECT ROUND(0.66, 0)
    Arithmetic overflow exception
    SELECT 1.0 * ROUND(0.66, 0) = 1;

    Est-ce normal cela???
    SqlServer 2005
    Groupe OnePoint
    Pascal Wick
    Programmeur-Analyste Sr.

  2. #2
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Points : 13 314
    Points
    13 314
    Par défaut
    C'est vrai que c'est amusant.

    Car si on fait

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    PRINT ROUND(0.66, 0)
    Ca marche, de même que :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT CAST(ROUND(0.66, 0) as decimal)

    Je ne réponds pas aux questions techniques par MP ! Le forum est là pour ça...


    Une réponse vous a aidé ? utiliser le bouton

    "L’ennui dans ce monde, c’est que les idiots sont sûrs d’eux et les gens sensés pleins de doutes". B. Russel

  3. #3
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 768
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 768
    Points : 52 719
    Points
    52 719
    Billets dans le blog
    5
    Par défaut
    Normal ! Lorsque vous ne précisez pas le type de données comme c'est le cas de 0.66, SQL Server le transtype dans le type le plus juste et dans votre cas, c'est un NUMERIC(2,2).

    le code que vous donnez revient donc à faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT ROUND(CAST(0.66 AS NUMERIC(2,2)), 0)
    Ce qui immanquablement provoque une erreur de dépassement car arrondir 0.66 sans décimale revient à 1 et 1 hne peut pas tenir dans un NUMERIC(2,2), mais dans un NUMERIC(3,2) !!!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT ROUND(CAST(0.66 AS NUMERIC(3,2)), 0)
    Les jeunes développeurs oublient toujours que SQL est un langage typé !
    Donc, mettre le bon type de données !!!

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 01/12/2008, 19h33
  2. Quelqu'un peut m'expliquer ce programme?
    Par checksum18 dans le forum C
    Réponses: 4
    Dernier message: 16/05/2008, 10h08
  3. Réponses: 0
    Dernier message: 10/08/2007, 17h30
  4. [DOM] quelqu un peut m expliquer : getelementbyID
    Par hkahil dans le forum Général JavaScript
    Réponses: 11
    Dernier message: 26/07/2007, 10h01
  5. quelqu'un peut m'expliquer ce "Type"
    Par bassim dans le forum Langage
    Réponses: 9
    Dernier message: 21/01/2007, 15h08

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