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 :

[SQL Server 2005] Update de plusieurs lignes et requête paramétrée


Sujet :

MS SQL Server

  1. #1
    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 : 42
    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
    Points : 12 371
    Points
    12 371
    Par défaut [SQL Server 2005] Update de plusieurs lignes et requête paramétrée
    Bonjour,

    Je voudrais savoir s'il est possible de récupérer des ID sans passer par une table temporaire.
    Voici mon exemple :

    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
     
     
    CREATE PROCEDURE spGetLigneTable
    	@nbLignes INT
    AS
    BEGIN
    	IF @nbLignes IS NULL
    	BEGIN
    		RAISERROR('Input parameter @nbLignes has to be filled', 16, 1)
    		RETURN
    	END
     
    	EXEC ('SELECT TOP '+ @nbLignes +' * INTO #MaTableTempo FROM MaTable WHERE ENCOURS = 0
     
    	UPDATE MaTable
    	SET ENCOURS = 1
    	WHERE ID_MaTable in (SELECT ID_MaTable FROM #MaTableTempo)
     
    	SELECT * FROM #MaTableTempo
     
    	DROP TABLE #MaTableTempo
    	')
    END
    Je trouve cette portion de code assez brute, ne peut-on pas faire quelque cohse de plus élégant ?

    En vous remerciant de votre aide,

    ElSuket

  2. #2
    Expert confirmé
    Avatar de rudib
    Homme Profil pro
    Fakir SQL Server & NoSQL
    Inscrit en
    Mai 2006
    Messages
    2 573
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Fakir SQL Server & NoSQL

    Informations forums :
    Inscription : Mai 2006
    Messages : 2 573
    Points : 4 043
    Points
    4 043
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    	UPDATE TOP (@nbLignes) MaTable
    	SET ENCOURS = 1
    	WHERE ENCOURS = 0
    Rudi Bruchez
    Rudi Bruchez EIRL, solutions MS SQL Server et NoSQL
    LinkedIn - [Outil libre de diagnostic SQL Server : Sql Trismegiste]
    LIVRES : Optimiser SQL Server -
    Microsoft SQL Server 2012 Security Cookbook
    - les bases de données NoSQL

    e-learning : LinkedIn Learning - Pluralsight

  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 : 42
    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
    Points : 12 371
    Points
    12 371
    Par défaut
    Merci, je ne savais pas qu'on pouvait faire cela.

    M'en vais lire la doc sur les possibilités de UPDATE

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

Discussions similaires

  1. SQL Server 2005 - Réplication de plusieurs milliers de tables
    Par mad_martigan dans le forum Réplications
    Réponses: 5
    Dernier message: 16/09/2010, 17h25
  2. [SQL SERVER 2005] Update avec un SELECT
    Par djilos dans le forum Développement
    Réponses: 1
    Dernier message: 24/04/2010, 10h23
  3. [SQL Server 2005] Comment désactiver plusieurs jobs en seule action ?
    Par clementratel dans le forum Administration
    Réponses: 5
    Dernier message: 08/12/2009, 09h49
  4. [SQL SERVER 2005] tracer l'exécution d'une requête
    Par AllyKo dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 14/05/2008, 09h10
  5. [SQL Server 2005] Update et alias
    Par Tartenpion dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 07/01/2008, 16h02

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