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 :

Problème insert BOOLEAN dans une table temporaire


Sujet :

MS SQL Server

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2011
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Novembre 2011
    Messages : 38
    Points : 32
    Points
    32
    Par défaut Problème insert BOOLEAN dans une table temporaire
    Bonjour,

    Je suis novice en SQL et je souhaiterais écrire une requête toute simple qui permettrait de faire un contrôle de cohérence de date.

    Je m'explique :

    J'ai une table A qui contient des dates aux format 2015-10-31 (si on prend le mois d'octobre pour exemple), et une clé primaire au format 201510.
    Je souhaiterais vérifier la cohérence entre la clé primaire et toutes les autres dates converties au même format que la clé primaire.
    En gros vérifier que les 6 premiers chiffres de chaque dates sont égaux à 201510 pour le mois d'octobre, etc...

    Pour ça, je voudrais créer une table temporaire de booléens avec comme entête chaque colonne de ma table A, puis en dessous une ligne de booléens qui me dit "1" si la date convertie est égale à la clé primaire, "0" sinon (ou TRUE/FALSE peu importe).

    Le problème c'est que je n'arrive pas à insérer une ligne de booléens dans ma table temporaire...

    Voici ma requête :


    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
    USE [TABLES]
    GO
     
    DECLARE @DT_arrete_check as Bit
     
    SET @DT_arrete_check = ((SELECT CONVERT(VARCHAR(6), DT_arrete, 112) FROM A WHERE [CLE]=201510) = (SELECT [CLE] FROM A WHERE [CLE]=201510))
     
    CREATE TABLE #CHECK_DATES(
    	[STRING][varchar](64) NOT NULL,
    	[test][Bit] NOT NULL)
     
    INSERT INTO #CHECK_DATES
    	VALUES('DT_arrete_check',@DT_arrete_check)
     
    SELECT *
    FROM #CHECK_DATES
    Et ça me met :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Msg 102, Level 15, State 1, Line 4
    Incorrect syntax near '='.
    En pointant vers le "=" de l'égalité dans le SET.

    Je reprécise que je bosse sur SQL-Server.
    C'est sans doute une erreur débile mais je connais pas encore super bien ce langage et j'ai beau parcourir les forums je ne vois pas ce qui cloche...

    Si l'un d'entre vous connaît le petit tips pour arriver à mes fins ce serait génial!
    Merci à vous !

  2. #2
    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
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Le booléen n'existe pas sous SQL Server. une colonne de type BIT prend 0 ou 1 et peut être NULL

    Pour votre affectation, il faut faire par exemple
    :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    IF ((SELECT CONVERT(VARCHAR(6), DT_arrete, 112) FROM A WHERE [CLE]=201510) = (SELECT [CLE] FROM A WHERE [CLE]=201510))
    SET @DT_arrete_check = 1
    ELSE
    SET @DT_arrete_check  = 0
    Vous pourriez aussi plus simplement ajouter cette colonne en tant que colonne calculée.

    Quel est le but final de l'opération ?

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2011
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Novembre 2011
    Messages : 38
    Points : 32
    Points
    32
    Par défaut
    J'ai finalement réussi en détournant la question,

    j'ai mis des clauses IF et inséré des valeurs 1 ou 0 en fonction de la cohérence.
    C'est plus crade mais ça fonctionne!

    Merci encore pour votre aide !

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 769
    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 769
    Points : 52 720
    Points
    52 720
    Billets dans le blog
    5
    Par défaut
    Citation Envoyé par jslpfasc2 Voir le message
    ...
    J'ai une table A qui contient des dates aux format 2015-10-31 (si on prend le mois d'octobre pour exemple), et une clé primaire au format 201510.
    Je souhaiterais vérifier la cohérence entre la clé primaire et toutes les autres dates converties au même format que la clé primaire.
    En gros vérifier que les 6 premiers chiffres de chaque dates sont égaux à 201510 pour le mois d'octobre, etc...
    Ce que vous faites est inepte, aberrant et contre performant.....

    Commencez déjà par apprendre qu'une date n'a pas de format. Une date est un type de données. Nous n'en somme plus au CoBOL qui stockait toutes les données sous forme de chaines de caractère !
    A lire : http://sqlpro.developpez.com/cours/sqlaz/erreurs/

    Quel est le but exact de cette horreur ?

    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/ * * * * *

Discussions similaires

  1. Réponses: 15
    Dernier message: 28/10/2011, 15h45
  2. [MySQL] problème insertion donnée dans une table
    Par thebestxav dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 30/04/2011, 20h01
  3. [JSP]probleme d'insertion float dans une table
    Par karamazov994 dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 14/04/2005, 11h49
  4. Insertion valeure dans une table
    Par krfa1 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 29/03/2005, 10h50
  5. Problème de dépendances dans une table
    Par PrinceMaster77 dans le forum Outils
    Réponses: 1
    Dernier message: 22/11/2004, 12h39

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