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 :

Affecter un numéro de ticket


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Mai 2011
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Biens de consommation

    Informations forums :
    Inscription : Mai 2011
    Messages : 41
    Par défaut Affecter un numéro de ticket
    Bonsoir,

    Je voudrais affecter à une liste lambda un numéro automatique qui commencerait à X, incrémenté par pas de 1.

    Exemple : 300 lignes auxquelles je dois affecter un numéro (peu importe l'ordre) de 1300 à 1600. Aujourd'hui la procédure qui le fait passe par un curseur (dont je voudrais me débarrasser), mais je suis persuadé que les instances compétentes ici bas me proposeraient bien un petit SELECT qui ajouterait automatiquement 1 au précédent (je suis sous SQL SERVER 2000 donc le ROW_NUMBER est proscrit...)

    Merci d'avance !

  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
    Par défaut
    Bonjour,

    En effet, un row_number aurait bien fait l'affaire...


    sans row_number, ni CTE, je ne vois pas de solution sans table temporaire :

    1/ créez un table temporaire, contenant le résultat de votre requête, et une colonne supplémentaire "Rang" initialement à NULL

    2/ affectez le rang :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    DECLARE @N INT
    SET @N = 1300
     
    UPDATE #Temp
        SET Rang = @N,
        @N = @N + 1

    3/ et zou !
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SELECT MesColonnes
    FROM #Temp

    Il y a peut être mieux (si quelqu'un est plus inspiré que moi...) mais je pense que ce sera toujours mieux qu'un curseur...

  3. #3
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Bonjour,

    Il suffit en fait de rajouter un CASE, s'il y a plus de lignes que la plage à mettre à jour :

    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
    36
    37
    38
    39
    40
    41
    42
    SET NOCOUNT ON
     
    -- Creation de la table
    CREATE TABLE dbo.toto
    (
    	toto varchar(16)
    	, ticket int
    )
     
    -- Peuplement de la table
    DECLARE @i int
    SET @i = 1
     
    WHILE @i <= 400
    BEGIN
    	INSERT	INTO dbo.toto (toto)
    	SELECT	'toto_' + CAST(@i AS varchar(10))
     
    	SET @i = @i + 1
    END
    GO
     
     
    DECLARE @start int
    	, @range int
     
    SELECT	@start = 1300
    	, @range = 300
     
    ----------------------------------
    DECLARE @limit int
    SET	@limit = @start + @range
     
    UPDATE	dbo.toto
    SET	ticket = @start
    	, @start = CASE
    			WHEN @start <= @limit - 1 THEN @start + 1
    			ELSE NULL -- ou ticket si l'on ne souhaite pas que la valeur soit changée
    		END
     
    SELECT	*
    FROM	dbo.toto
    @++

  4. #4
    Membre averti
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Mai 2011
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Biens de consommation

    Informations forums :
    Inscription : Mai 2011
    Messages : 41
    Par défaut
    Merci pour ces réponses !
    Ce qui est curieux dans l'exemple de aieeeuuuuu, c'est que si l'on commence à 1000, le premier a pour ticket le numéro 1001 alors que l'update précise @n = @n + 1 après l'affectation de @n au champ ticket ?

  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
    en fait, ce n'est pas la façon d’écrire la requête, mais le moteur qui détermine l'ordre d'affectation...
    Et le moteur à décidé, comme le montre le plan d’exécution, d’incrémenter @N avant de mettre à jour la colonne...

    Bah, initialisons @N = 1299

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

Discussions similaires

  1. Affectation numéro via VBA
    Par chacha21 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 21/01/2013, 19h45
  2. Réponses: 3
    Dernier message: 31/08/2007, 19h31
  3. récuperation d'un numéro de téléphone
    Par herzleid dans le forum Delphi
    Réponses: 4
    Dernier message: 17/07/2007, 10h25
  4. Calcul des numéros de semaine d'un calendrier
    Par Invité dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 06/11/2002, 22h29
  5. [MaskEditBox] Affecter avec un réel
    Par fikou dans le forum Général VBA
    Réponses: 6
    Dernier message: 16/09/2002, 10h28

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