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 :

Tirage aléatoire selon une variable


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Femme Profil pro
    Chargé d'etude statistiques
    Inscrit en
    Juin 2015
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Chargé d'etude statistiques

    Informations forums :
    Inscription : Juin 2015
    Messages : 6
    Par défaut Tirage aléatoire selon une variable
    Bonjour à tous,

    Je cherche à faire un tirage aléatoire d'identifiant selon une variable. Je vous explique, je dispose :
    -d'une table 1 avec l'identifiant d'une agence (AGENCE), le nombre de personne travaillant dans l'agence (ETP) et le nombre de contacts (Nbcontacts=ETP*16).
    -d'une table 2 avec l'identifiant client (CLIENT), l'identifiant agence (AGENCE)

    Voici des extraits de ces 2 tables

    Table 1

    Agence ETP NBcontacts
    153 6 96
    154 7,3 117
    155 4 64
    156 6 96
    157 4 64
    158 8 128
    159 9,4 150
    160 6,1 98

    Table 2

    CLIENT AGENCE
    00012 153
    00013 153
    00014 153
    00015 154
    00016 154

    Mon objectif est de récupérer N (=Nbcontacts) identifiant client (CLIENT) de la table 2 de manière aléatoire selon l'identifiant de l'agence.
    Donc par exemple je veux récupérer 96 identifiants client de l'agence 153, 117 identifiants client de l'agence 154.
    Je précise qu'il est très important de sélectionner les 96 clients de l'agence de façon aléatoire dans la table et non pas les 96 premiers appartenant à l'agence.

    Avez-vous des idées ?

    Je vous remercie d'avance pour votre aide.

  2. #2
    Membre éclairé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2008
    Messages
    699
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Boutique - Magasin

    Informations forums :
    Inscription : Octobre 2008
    Messages : 699
    Par défaut
    SELECT TOP <Le nombre> * FROM <La table> ORDER BY NEWID()

  3. #3
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 002
    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 : 22 002
    Billets dans le blog
    6
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    WITH 
    T0 AS (
    SELECT *, NEWID() AS ALEA
    FROM   Table2),
    T1 AS (
    SELECT *, ROW_NUMBER() OVER(PARTITION BY AGENCE ORDER BY ALEA) AS N
    FROM   T0)
    SELECT *
    FROM   T1
           JOIN Table1 AS T
    	        ON T1.AGENCE = T.AGENCE
    			AND N <=  NBcontacts;
    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. Tirage échantillon aléatoire sur une variable
    Par Sandrine J dans le forum SAS STAT
    Réponses: 4
    Dernier message: 24/07/2012, 15h47
  2. Réponses: 7
    Dernier message: 10/11/2006, 09h03
  3. JTree, icone d'un noeud selon une variable
    Par remayy dans le forum Composants
    Réponses: 3
    Dernier message: 17/10/2006, 09h26
  4. Tirage aléatoire dans une base donnée
    Par leloup84 dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 30/01/2006, 16h13
  5. [POO] Déclaration de classe selon une variable
    Par Michaël dans le forum Langage
    Réponses: 1
    Dernier message: 07/01/2006, 18h33

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