Précédent   Forum des professionnels en informatique > PHP > Langage > Regex
Regex Forum d'entraide sur les expressions rationnelles PHP. Avant de poster -> FAQ regex, Cours de regex et Sources de regex
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 12/12/2006, 23h21   #1
Invité régulier
 
Inscription : mai 2003
Messages : 17
Détails du profil
Informations forums :
Inscription : mai 2003
Messages : 17
Points : 7
Points : 7
Par défaut expression rationnelle par php pour requete mysql

Bonjour,

Je souhaite extraire des elements d'une requetes SQL.
Mon but est de recuperer les elements avant le from de la requete et les elements après le from. Mais la requete comporte plusieurs from et je ne souahites recuperer les infos que du 1er from.
Voici une requete exemple :

Code sql :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
  SELECT T.ID,T.AGT_NOM,T.AGT_PRE,ROUND( SUM( T.CAE ) , 2 ),ROUND( SUM( T.CAR ) , 2 )
  FROM
  (
  (SELECT agent_id ID, agent_nom AGT_NOM, agent_prenom AGT_PRE,
  (SELECT SUM( action_even_ca ) FROM action_even WHERE action_even_vente = 'N' AND action_even_agent_affect = agent_id ) CAE
  FROM agent,action_even
  WHERE action_even_agent_affect = agent_id
  GROUP BY agent_id ORDER BY agent_nom, agent_id)
  UNION ALL
  (SELECT agent_id ID, agent_nom AGT_NOM, agent_prenom AGT_PRE,
  (SELECT SUM( affaire_ca_realise ) FROM affaire WHERE affaire_vente = 'N' AND affaire_agent_affect = agent_id ) CAE
  FROM agent,affaire
  WHERE affaire_agent_affect = agent_id
  GROUP BY agent_id ORDER BY agent_nom, agent_id)
  ) T  GROUP BY 1;

Mon but est de recuperer:
Citation:
T.ID,T.AGT_NOM,T.AGT_PRE,ROUND( SUM( T.CAE ) , 2 ),ROUND( SUM( T.CAR ) , 2 )
Et aussi :
Code sql :
1
2
3
4
5
6
7
8
9
10
11
12
13
(
  (SELECT agent_id ID, agent_nom AGT_NOM, agent_prenom AGT_PRE,
  (SELECT SUM( action_even_ca ) FROM action_even WHERE action_even_vente = 'N' AND action_even_agent_affect = agent_id ) CAE
  FROM agent,action_even
  WHERE action_even_agent_affect = agent_id
  GROUP BY agent_id ORDER BY agent_nom, agent_id)
  UNION ALL
  (SELECT agent_id ID, agent_nom AGT_NOM, agent_prenom AGT_PRE,
  (SELECT SUM( affaire_ca_realise ) FROM affaire WHERE affaire_vente = 'N' AND affaire_agent_affect = agent_id ) CAE
  FROM agent,affaire
  WHERE affaire_agent_affect = agent_id
  GROUP BY agent_id ORDER BY agent_nom, agent_id)
  ) T  GROUP BY 1;


Voici un essai qui ne fonctionne pas :
Code :
preg_match("/SELECT(.*^(?:FROM))/i",$query2,$parts)
J'ai fais pleins d'essais et je desespère.

Donc j'en demande aux pros des expressions rationnelles.

Merci pour vos reponses.
dgedge est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/12/2006, 08h20   #2
Membre émérite
 
Inscription : mai 2004
Messages : 709
Détails du profil
Informations personnelles :
Localisation : Belgique

Informations forums :
Inscription : mai 2004
Messages : 709
Points : 852
Points : 852
Simplement comme ceci?

Code :
preg_match('#SELECT\s*(.*?)\s*FROM#si', $query2, $parts)
__________________
:q :q! :wq :w :w! :wq! :quit :quit! :help help helpquit quit quithelp
:quitplease :quitnow :leave :shit ^X^C ^C ^D ^Z ^Q QUITDAMMIT
Jabber: ripat at im.apinc.org
ripat est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/12/2006, 09h47   #3
Invité régulier
 
Inscription : mai 2003
Messages : 17
Détails du profil
Informations forums :
Inscription : mai 2003
Messages : 17
Points : 7
Points : 7
merci ca marche nickel
dgedge 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 23h44.


 
 
 
 
Partenaires

Hébergement Web