Précédent   Forum des professionnels en informatique > Bases de données > Langage SQL
Langage SQL Forum d'entraide sur le langage SQL et sur les questions liées à la conception de schéma (DDL). Cours SQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 21/07/2011, 10h23   #1
Membre du Club
 
Inscription : novembre 2006
Messages : 270
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 270
Points : 43
Points : 43
Par défaut Avoir le résultat de plusieurs requêtes (count) sur la même ligne?

Bonjour,

J'aimerai avoir dans un seul affichage le résultat de plusieur requêtes.
En gros, je voudrais en une seule requête connaitre le nombre d'enregistrements de toutes mes tables.
Quelque chose du style:
Code sql :
1
2
3
4
5
 
SELECT `nb_table1`, `nb_table2`, `nb_table3`(
	SELECT COUNT(*) AS `nb_table1` FROM `table1`;
	SELECT COUNT(*) AS `nb_table2` FROM `table2`;
	SELECT COUNT(*) AS `nb_table3` FROM `table3`);
Si quelqu'un connait la syntaxe pour arriver à ce résultat je suis preneur.
Par avance merci.
takinelinfo est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/07/2011, 10h34   #2
Expert Confirmé
 
Homme
Inscription : mai 2002
Messages : 1 638
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 29
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : mai 2002
Messages : 1 638
Points : 2 630
Points : 2 630
Bonjour,

Pour ce faire vous allez devoir requête les vues systèmes afin de faire une requete générique.
Ceci est dépendant de votre sgbd donc recherchez dans ce sens là.

Une autre solution, plus bourrine et chiante à maintenir, serai de faire une requête en utilisant "union all" :

Code :
1
2
3
4
5
6
7
 
SELECT "table1" AS nomTable, count(*) AS cnt
FROM table1 
union ALL
SELECT "table2" AS nomTable, count(*) AS cnt
FROM table2
union ALL ...
punkoff est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/07/2011, 16h47   #3
Membre éclairé
 
Avatar de boussafi
 
Homme
Ingénieur développement logiciels
Inscription : septembre 2007
Messages : 342
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Algérie

Informations professionnelles :
Activité : Ingénieur développement logiciels
Secteur : Industrie

Informations forums :
Inscription : septembre 2007
Messages : 342
Points : 397
Points : 397
Envoyer un message via Yahoo à boussafi Envoyer un message via Skype™ à boussafi
je vous propose une autre solution; le resultat sur une meme ligne.

Code :
1
2
3
4
5
SELECT *
FROM
(SELECT count(*) AS compte_1 FROM table_1),
(SELECT count(*) AS compte_2 FROM table_2),
(SELECT count(*) AS compte_3 FROM table_3)
boussafi est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 26/07/2011, 13h58   #4
Membre du Club
 
Inscription : novembre 2006
Messages : 270
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 270
Points : 43
Points : 43
Merci beaucoup
takinelinfo est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 00h33.


 
 
 
 
Partenaires

Hébergement Web