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

Langage SQL Discussion :

Modifier un Select pour filtrer les tables en fonction d'un intervalle de dates


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Novembre 2012
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2012
    Messages : 37
    Points : 35
    Points
    35
    Par défaut Modifier un Select pour filtrer les tables en fonction d'un intervalle de dates
    Bonjour,
    Très bonne année à tous.

    J'aimerai adapter le select ci dessous pour filtrer les tables en fonction de l'intervalle de date entre compris entre 201504 et 201604.
    J'ai essayé comme ci dessous mais il me sort des table en dehors de l'intervalle.
    Pourriez vous me dire comment adapter ce morceau de code svp?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT TABLE_CATALOG, TABLE_SCHEMA, TABLE_NAME
    FROM   INFORMATION_SCHEMA.tables
    WHERE  TABLE_TYPE = 'BASE TABLE' AND 
    AND TABLE_NAME LIKE '%?_20150[4-9]' ESCAPE '?' 
    OR TABLE_NAME LIKE '%?_20151[0-2]' ESCAPE '?' 
    OR TABLE_NAME LIKE '%?_20160[0-4]' ESCAPE '?' 
    AND TABLE_NAME LIKE 'AboLogs%' OR TABLE_NAME LIKE 'AlertLogs%' OR TABLE_NAME LIKE 'AckLogs%'OR TABLE_NAME LIKE 'MsgLogs%'OR TABLE_NAME LIKE 'mailLogs%'
    Merci de votre aide

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 199
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 199
    Points : 12 775
    Points
    12 775
    Par défaut
    Bonjour,
    je ne comprends pas très bien la syntaxe utilisée ici dans le Where, mais quoi qu'il en soit quand on mixe des AND et des OR, il est plus que conseillé d'ajouter des parenthèses:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT TABLE_CATALOG, TABLE_SCHEMA, TABLE_NAME
    FROM   INFORMATION_SCHEMA.tables
    WHERE  TABLE_TYPE = 'BASE TABLE' AND 
    AND (TABLE_NAME LIKE '%?_20150[4-9]' ESCAPE '?' 
    OR TABLE_NAME LIKE '%?_20151[0-2]' ESCAPE '?' 
    OR TABLE_NAME LIKE '%?_20160[0-4]' ESCAPE '?' )
    AND (TABLE_NAME LIKE 'AboLogs%' OR TABLE_NAME LIKE 'AlertLogs%' OR TABLE_NAME LIKE 'AckLogs%'OR TABLE_NAME LIKE 'MsgLogs%'OR TABLE_NAME LIKE 'mailLogs%')

    Ici par exemple il faut "regrouper" les critères de date d'un côté, et ceux sur le reste de l'autre.

    Tatayo.

  3. #3
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 137
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 137
    Points : 38 894
    Points
    38 894
    Billets dans le blog
    9
    Par défaut
    S'il y avait ne serait-ce qu'une seule bonne raison pour nommer les tables en fonction de l'année j'aimerai bien la connaitre !

  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 782
    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 782
    Points : 52 780
    Points
    52 780
    Billets dans le blog
    5
    Par défaut
    Citation Envoyé par escartefigue Voir le message
    S'il y avait ne serait-ce qu'une seule bonne raison pour nommer les tables en fonction de l'année j'aimerai bien la connaitre !
    La bêtise !

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

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Novembre 2012
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2012
    Messages : 37
    Points : 35
    Points
    35
    Par défaut
    Merci messieurs pour vos réponses

  6. #6
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Novembre 2012
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2012
    Messages : 37
    Points : 35
    Points
    35
    Par défaut
    Je ne suis pas DBA ni developpeur.
    J'ignore donc si c'est une bonne raison mais notre espace disque est limité et les écritures dans ces tables sont quasi permanentes, ce qui provoque une forte fragmentation des indexs et sature rapidement l'espace disque.
    Les jobs de rebuild des index durent plus longtemps si la table est grosse que si elle est divisée en plusieurs tables pour chaque MM-YYYY.
    En supprimant les anciennes tables je maintiens l'espace disque à peu près constant et j'évite de fragmenter les index trop souvent.

  7. #7
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 782
    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 782
    Points : 52 780
    Points
    52 780
    Billets dans le blog
    5
    Par défaut
    Il suffirait de mettre en œuvre le partitionnement par rapport à une colonne date et de ne travailler que sur une seule table et le tour est joué !

    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: 2
    Dernier message: 12/09/2014, 21h31
  2. [MySQL] requete pour faire un select dans toutes les tables pour trouver le titre
    Par japhettchabao dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 12/09/2014, 20h02
  3. [AC-2003] Modifier un champ pour tous les enregistrement d'une table
    Par Meph-Dev dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 15/06/2009, 08h41
  4. Réponses: 18
    Dernier message: 11/07/2007, 17h38
  5. Requete select pour récupérer les no match entre 2 tables
    Par Celina dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 16/12/2003, 11h59

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