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

Requêtes MySQL Discussion :

[MySQL]Recuperer la liste des tables utilisées...


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre chevronné
    Homme Profil pro
    /
    Inscrit en
    Février 2003
    Messages
    434
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : /

    Informations forums :
    Inscription : Février 2003
    Messages : 434
    Par défaut [MySQL]Recuperer la liste des tables utilisées...
    Bonjour/soir,

    Je tente de creer une classe PHP qui enregistre le resultat des SELECT en vue de créer un cache local des données. Il me faut pour ce faire avoir le lien cache -> table correspondante afin de pouvoir le mettre à jour lors de modification/ajout/supreession de données dans la table.

    J'en viens donc à ma question, existe-t-il un moyen de récuperer la liste des tables utilisée dans une requête?

  2. #2
    Membre chevronné
    Homme Profil pro
    /
    Inscrit en
    Février 2003
    Messages
    434
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : /

    Informations forums :
    Inscription : Février 2003
    Messages : 434
    Par défaut
    Voici où j'en suis dans mes recherches. J'ai trouvé un moyen (pas particulièrement élégant, je trouve, mais qui fonctionne) pour obtenir cette liste pour les requetes du type SELECT.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    //SELECT  
    $data = mysql_query('EXPLAIN '.$Query);
    $i = 0; 
    $result = array();
    while ($table = mysql_fetch_array($data)){
    	$result[$i] = $table['table'];
    	$i++;
    }	 
    return $result;
    Il ne reste plus qu'à s'attaquer aux UPDATE, INSERT et DELETE. Je pense pour l'instant parser la requete car il me semble qu'il n'est pas possible de faire ces actions sur plusieurs tables différentes mais j'ai peur qu'une subtilité syntaxique de MySQL permette une syntaxe que je n'aurais pas prévue et donc mette à genoux ma fonction. Je préférerai donc que le serveur me dise lui-même la réponse. Lui au moins, il sait

  3. #3
    Rédacteur

    Avatar de Yogui
    Homme Profil pro
    Directeur technique
    Inscrit en
    Février 2004
    Messages
    13 721
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yonne (Bourgogne)

    Informations professionnelles :
    Activité : Directeur technique

    Informations forums :
    Inscription : Février 2004
    Messages : 13 721
    Par défaut
    Salut

    Tu as de la chance, nous nous sommes penchés sur ce problème ici :
    http://www.developpez.net/forums/viewtopic.php?t=466110

  4. #4
    Membre chevronné
    Homme Profil pro
    /
    Inscrit en
    Février 2003
    Messages
    434
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : /

    Informations forums :
    Inscription : Février 2003
    Messages : 434
    Par défaut
    Merci beaucoup!
    Comment ai-je pu passer à coté de ce post?
    J'ai testé ce code mais il ne répond pas encore à mes attentes, par exemple
    • SELECT FROM t1,t2 ... ->t1
    • INSERT LOW_PRIORITY ... -> LOW_PRIORITY

    Cela me donne toutefois une bonne base pour commencer.

  5. #5
    Membre chevronné
    Homme Profil pro
    /
    Inscrit en
    Février 2003
    Messages
    434
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : /

    Informations forums :
    Inscription : Février 2003
    Messages : 434
    Par défaut
    Voilà, je pense être arrivé a une fonction qui fait ce que je veux. J'ai sué un peu car c'est la première fois que je me confronte aux regex. Je suis donc preneur de toute corection et/ou implification et/ou optimisation que vous pourriez voir et/ou trouver (J'ai acheté un stock de et/ou en promo, faut bien que je les utilise ).

    Voici le code pour ceux que ca interesseraient
    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
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    	 /**********************************************************************
    	 *	Extract the table used in a query
    	 ***********************************************************************
    	 *	@param $query  	
    	 *	@retrun : array containing the table's name
    	 **********************************************************************/				
    	 function ExtractTable($Query){
    	 	echo $Query.'<br>';
    		//DELETE
    		if 	   (preg_match('#(?:DELETE (?:.*)FROM\s* )(.*)#', $Query, $Substring)){
    			$Substring = $Substring[1];
    			if 	   (preg_match('#(.*)(?:USING.*)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)(?:WHERE.*)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)(?:ORDER BY.*)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)(?:LIMIT.*)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)#', $Substring, $resultat)){}
    			else {
    				echo 'The query has not been parsed<br>'.$Query.'<br>';
    			};				
    		}
    		//INSERT
    		elseif (preg_match('#(?:INSERT\s+)(?:LOW_PRIORITY|DELAYED)?\s*(?:IGNORE)?\s*(?:INTO)?\s*([\w\s,]*)(?:.*)
    //J'ai artificiellement coupe cette ligne pour ne pas trop déformer l'affichage sur le forum
    (?:VALUES.*|SELECT.*)#',$Query,$resultat)){}
    		//LOAD DATA INFILE
    		elseif (preg_match("#(?:LOAD \s*DATA (?:.*)INFILE (?:.*)INTO TABLE\s*)([a-z0-9_.]*)#",$Query,$resultat)){}
    		//REPLACE
    		elseif (preg_match('#(?:REPLACE\s+)(?:LOW_PRIORITY|DELAYED)?\s*(?:INTO)?\s*([\w\s,]*)(?:VALUES.*)#',$Query,$resultat)){}
    		//UPDATE
    		elseif (preg_match('#(?:UPDATE\s+(?:LOW_PRIORITY)?\s*(?:IGNORE)?\s*)(.*)(?:SET.*)#', $Query, $resultat)){}
    		//SELECT
    		elseif (preg_match('#(?:SELECT (?:.*)FROM \s*)(.*)#', $Query, $Substring)){
    			$Substring = $Substring[1];
    			if (preg_match('#(.*)(?:CROSS|INNER|STRAIGHT_JOIN|LEFT.*|NATURAL|RIGHT)#', $Substring, $resultat)){}
    			elseif     (preg_match('#(.*)(?:WHERE)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)(?:GROUP BY)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)(?:HAVING)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)(?:ORDER BY)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)(?:LIMIT)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)(?:PROCEDURE)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)(?:FOR UPDATE|LOCK IN SHARE MODE)#', $Substring, $resultat)){}
    			elseif (preg_match('#(.*)(?:CROSS|INNER|STRAIGHT_JOIN|LEFT|NATURAL|RIGHT)#', $Substring, $resultat)){}
    			else {
    				echo 'The query has not been parsed<br>'.$Query.'<br>';
    			};	
    			//JOIN
    			if     (preg_match('#(?:JOIN) \s*(.*) (?:ON)#', $Query, $resultat2)){
    				$resultat[1] .= ','.$resultat2[1];
    			}
    		} 
    		//TROUBLE
    		else {
    			echo 'The query has not been parsed<br>'.$Query.'<br>';
    		};	
    		$resultat[1] = ereg_replace(' ', '',$resultat[1]); 
    		return explode(',',$resultat[1]);
    	 }
    Pour ceux que ca interesse, voici les (pseudo-)requetes que que j'ai employé pour mes tests:
    • DELETE FROM db.t1,t2 USING t1,t2,t3 WHERE t1.id=t2.id AND t2.id=t3.id
    • DELETE FROM t1,t2 WHERE t1.id=t2.id ORDER BY t3.id
    • DELETE FROM t1,t2 ORDER BY t3.id
    • DELETE FROM t1,t2 WHERE t1.id=t2.id LIMIT BY t3.id
    • DELETE FROM nom_de_table
    • INSERT INTO table, table2 (a,b,c) VALUES (4,5,6) ON DUPLICATE KEY UPDATE c=9;
    • INSERT DELAYED INTO table, table2 (a,b,c) VALUES (4,5,6) ON DUPLICATE KEY UPDATE c=9;
    • INSERT IGNORE INTO table, table2 (a,b,c) VALUES (4,5,6) ON DUPLICATE KEY UPDATE c=9;
    • INSERT INTO tblTemp2, table2 (fldID) SELECT tblTemp1.fldOrder_ID FROM tblTemp1 WHERE tblTemp1.fldOrder_ID > 100;
    • REPLACE INTO tblTemp2 VALUES (fldID);
    • LOAD DATA INFILE 'donnees.txt' INTO TABLE db.nom_de_table FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\n'
    • UPDATE persondata SET age=age*2, age=age+1;
    • UPDATE items,month SET items.price=month.price WHERE items.id=month.id;
    • SELECT CONCAT(last_name,', ',first_name) AS full_name FROM mytable ORDER BY full_name
    • SELECT a, COUNT(b) FROM test_table GROUP BY a DESC
    • SELECT user,MAX(salary) AS sum FROM users group by user HAVING sum>10
    • SELECT a, COUNT(b) FROM test_table ORDER BY a ASC
    • SELECT * FROM table LIMIT 5,10;
    • SELECT ... FROM table PROCEDURE ANALYSE([max elements,[max memory]])
    • SELECT * FROM table FOR UPDATE;
    • SELECT * FROM table LOCK IN SHARE MODE;
    • SELECT table1.* FROM table1 LEFT JOIN table2 ON table1.id=table2.id WHERE table2.id IS NULL;
    • SELECT table1.* FROM table11, table12 LEFT JOIN table21, table22 ON table1.id=table2.id WHERE table2.id IS NULL;

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

Discussions similaires

  1. Recuperer la liste des colonnes d'une table
    Par miai85 dans le forum Oracle
    Réponses: 1
    Dernier message: 12/07/2007, 11h44
  2. Recuperer la liste des tables utilisées...
    Par zaventem dans le forum Requêtes
    Réponses: 2
    Dernier message: 19/03/2006, 20h09
  3. Liste des tables d'une bases de données spécifique
    Par faridos23 dans le forum Requêtes
    Réponses: 3
    Dernier message: 26/08/2003, 22h20
  4. Réponses: 2
    Dernier message: 04/10/2002, 09h13

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