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 :

Détection front montant /descendant sur booléen dans une table


Sujet :

Développement SQL Server

  1. #1
    Membre à l'essai
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Août 2016
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Août 2016
    Messages : 29
    Points : 22
    Points
    22
    Par défaut Détection front montant /descendant sur booléen dans une table
    Bonjour à tous

    J'ai un programme OPC qui récupères les informations de mon automates et créent des tables SQL.

    Voici ce qui est déjà réalisé :

    Une table 'DLG' qui contient : un batchID (Increment par SQL, qui augmente à chaque nouvelle production) , une date/heure, une longueur de production (bigint) et plusieurs défauts (boolean)

    exemple :

    DLG
    Date&Time BatchId Lenght production Alarm1
    2017-03-03 14 :30 :000 1 5 0
    2017-03-03 14 :31 :000 2 5 1
    2017-03-03 14 :32 :000 3 0 0
    2017-03-03 14 :33 :000 3 5 1
    2017-03-03 14 :34 :000 3 10 0
    2017-03-03 14 :35 :000 3 15 1
    2017-03-03 14 :36 :000 3 20 1
    2017-03-03 14 :37 :000 3 25 0
    2017-03-03 14 :38 :000 3 30 1
    2017-03-03 14 :39 :000 3 35 1
    2017-03-03 14 :39 :000 3 40 1
    2017-03-03 14 :39 :000 3 45 1
    2017-03-03 14 :39 :000 3 50 1
    2017-03-03 14 :39 :000 3 55 0

    J'aimerais faire un view ou je prend chaque chaque d 'état : donc de 0 à 1 ("start") puis de 1 à 0 ("stop")

    exemple :

    Date&Time BatchId Lenght production Alarm1

    2017-03-03 14 :31 :000 2 5 1 (start stop)

    2017-03-03 14 :33 :000 3 5 1 (start stop)

    2017-03-03 14 :35 :000 3 15 1 (start
    2017-03-03 14 :36 :000 3 20 1 stop)

    2017-03-03 14 :38 :000 3 30 1 (start
    2017-03-03 14 :39 :000 3 50 1 stop)

    Comment je peux réalisé cela dans une view ? ou dois-je faire appel à une fonction ?

    Merci bien

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 761
    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 761
    Points : 52 547
    Points
    52 547
    Billets dans le blog
    5
    Par défaut
    Utilisez les fonctions de fenêtrage LEAD et LAG

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

  3. #3
    Membre à l'essai
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Août 2016
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Août 2016
    Messages : 29
    Points : 22
    Points
    22
    Par défaut réponse
    J'utilise SQL 2008 c'est fonction sont valide que à partir du 2012 d'après internet , mais merci

  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 761
    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 761
    Points : 52 547
    Points
    52 547
    Billets dans le blog
    5
    Par défaut
    Dans ce cas numérotez vos valeurs avec ROW_NUMBER et comparez la ligne actuelle avec la ligne d'avant.

    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. [AC-2007] enregistrer les données sur état dans une table
    Par ouahab dans le forum Access
    Réponses: 1
    Dernier message: 14/05/2012, 15h12
  2. Réponses: 1
    Dernier message: 03/11/2010, 11h41
  3. PB Lock sur delete dans une table
    Par greatmaster1971 dans le forum DB2
    Réponses: 10
    Dernier message: 06/07/2008, 20h49
  4. Correcteur orthographique sur champs dans une table
    Par com-ace dans le forum Access
    Réponses: 2
    Dernier message: 21/09/2006, 15h51
  5. [CSS]probleme de style sur cellules dans une table
    Par luimême dans le forum Mise en page CSS
    Réponses: 4
    Dernier message: 17/01/2006, 12h13

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