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

Développement SQL Server Discussion :

Calcul requête SQL


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Janvier 2010
    Messages
    19
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 19
    Par défaut Calcul requête SQL
    Bonjour ;


    le resultat de cette requette est en entier " 19 " parceque la colonne prodtime est declarer en entier ,, mais je veux afficher toujours le résultat en float

    ex dans ce cas : 19,808

    min(prodtime) = 2476 / 125 = 19,808

    svp comment convertir ??


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    select min(prodtime)  \ 125
    from lep_his.productiontime  
    where ksk in 
    (SELECT distinct [kSK] 
    FROM [LEPS].[LEP_HIS].[WorkTimes]
    where ksk  in ( SELECT distinct [KSK]      
    FROM [LEPS].[LEP_HIS].[WorkTimes]
    where StartTime between '2014-09-19 06:00:00' and '2014-09-19 07:00:00'
    and Workplace = 'ass12'  
    and DispositionCode = 'ok'))

  2. #2
    Membre émérite Avatar de GeekMokona
    Femme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Novembre 2011
    Messages
    327
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 45
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2011
    Messages : 327
    Par défaut
    Bonjour,

    Quel est ton SGBD (Oracle ,SQL Server, .... )????

  3. #3
    Membre averti
    Inscrit en
    Janvier 2010
    Messages
    19
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 19
    Par défaut
    SQL server , mercii


    Citation Envoyé par mokona18 Voir le message
    Bonjour,

    Quel est ton SGBD (Oracle ,SQL Server, .... )????

  4. #4
    Membre émérite Avatar de GeekMokona
    Femme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Novembre 2011
    Messages
    327
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 45
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2011
    Messages : 327
    Par défaut
    essaye

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     select min(cast( prodtime as float)) \ 125
     from lep_his.productiontime 
     where ksk in 
     (SELECT distinct [kSK] 
     FROM [LEPS].[LEP_HIS].[WorkTimes]
     where ksk in ( SELECT distinct [KSK] 
     FROM [LEPS].[LEP_HIS].[WorkTimes]
     where StartTime between '2014-09-19 06:00:00' and '2014-09-19 07:00:00'
     and Workplace = 'ass12' 
     and DispositionCode = 'ok'))

  5. #5
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Bonjour,

    Le signe de division est "/" et non "\".

    Il suffit de diviser par un type décimal, et non un entier. Par défaut, 125 est considéré comme un entier.

    Vous pouvez faire comme ceci :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT min(prodtime)  / 125.
    Voire, pour une meilleure lisibilité:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT min(prodtime)  / 125.0

  6. #6
    Membre averti
    Inscrit en
    Janvier 2010
    Messages
    19
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 19
    Par défaut
    j'ai trouvé la solution avec le code
    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
    select (cast(sum (prodtime) as numeric)) / ( count (ksk) * 11460 )
    from lep_his.productiontime  
    where ksk in 
    (SELECT distinct [kSK] 
    FROM [LEPS].[LEP_HIS].[WorkTimes]
    where ksk  in ( SELECT distinct [KSK]      
    FROM [LEPS].[LEP_HIS].[WorkTimes]
    where StartTime between '2014-09-22 09:00:00' and '2014-09-22 10:00:00'
    and Workplace = 'ass12'  
    and DispositionCode = 'ok'))
    --and ksk not in ( SELECT distinct [KSK]      
    --FROM [LEPS].[LEP_HIS].[WorkTimes]
    --where StartTime < @date1
    --and Workplace = 'ass12' 
    --and DispositionCode = 'ok')
    --)))


    mais lorsque j'ai déployer cette requite dans une procedure le resultat est encors en entier "74"



    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
    drop table #kosu2
    declare  @coef numeric
    declare @date1 datetime , @date2 datetime, @date3 datetime,@date4 datetime
     
     
    set @date1=DATEADD(hour,09,CONVERT(VARCHAR(10),DATEADD(d,-0,CONVERT(VARCHAR(10),GETDATE(),20)),20))
    set @date2=DATEADD(hour,10,CONVERT(VARCHAR(10),DATEADD(d,-0,CONVERT(VARCHAR(10),GETDATE(),20)),20))
     
    --select (cast(sum (prodtime) as numeric)) / ( count (ksk) * 11460 )
     
    set @coef = (select( cast(min (prodtime) as numeric ) / 125)
    --( count (ksk) * MAX (prodtime))
    from lep_his.productiontime  
    where ksk in 
    (SELECT distinct [kSK] 
    FROM [LEPS].[LEP_HIS].[WorkTimes]
    where ksk  in ( SELECT distinct [KSK]      
    FROM [LEPS].[LEP_HIS].[WorkTimes]
      where  StartTime between @date1 and @date2
    and Workplace = 'ass12'  
    and DispositionCode = 'ok')))
    --and ksk not in ( SELECT distinct [KSK]      
    --FROM [LEPS].[LEP_HIS].[WorkTimes]
    --where StartTime < @date1
    --and Workplace = 'ass12' 
    --and DispositionCode = 'ok')
     
     
     
     
    create table #kosu2 (total varchar(20),coef numeric)
     
    insert into #kosu2 values('kosu', @coef)
     
    select * from #kosu2
    le result souhaité est 74,432 mais le système affiche 74

    Citation Envoyé par aieeeuuuuu Voir le message
    Bonjour,

    Le signe de division est "/" et non "\".

    Il suffit de diviser par un type décimal, et non un entier. Par défaut, 125 est considéré comme un entier.

    Vous pouvez faire comme ceci :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT min(prodtime)  / 125.
    Voire, pour une meilleure lisibilité:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT min(prodtime)  / 125.0

Discussions similaires

  1. [Requête/SQL]ajouter un champ calculé dans une table
    Par zougna dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 17/04/2007, 19h09
  2. [Requête/SQL]Conditions dans un champs calculé
    Par taisherg dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 17/04/2007, 15h55
  3. [Requête/SQL]Calcul d'un solde dans une requête ou un état
    Par alalau dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 13/04/2007, 16h02
  4. [SQL] Grosse requête SQL + calculs
    Par nicopoal dans le forum PHP & Base de données
    Réponses: 22
    Dernier message: 19/01/2007, 14h18
  5. Récupérer la valeur des champs calculés dans une requète SQL dans vba
    Par FrédéricCM dans le forum Requêtes et SQL.
    Réponses: 12
    Dernier message: 28/06/2006, 16h29

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