Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> Wyrażenie reguralne
kr27
post
Post #1





Grupa: Zarejestrowani
Postów: 27
Pomógł: 0
Dołączył: 20.03.2007

Ostrzeżenie: (0%)
-----


Witam,

Bardzo proszę o pomoc w następującym problemie.
Mam następujący SQL:

  1. SELECT pr_a.pole1, pr_a.pole2, kl_a.pole3, kl_a.pole4 FROM produkty AS pr_a INNER JOIN klienci AS kl_a ON pr_a.pole = kl_a.pole


Potrzebuję "przeciągnąć" ten SQL przez jakaś funkcję, która zwróci mi (najlepiej w array) aliasy użytych tabel tj: "pr_a" i "kl_a".

Aliasy występują zawsze po "as", składają się z czterech znaków, z czego trzeci znak do "_", więc będą to np fragmenty:
" as ab_a"
" as ab_b"
" as za_a"

Uwaga. Czasami pole może mieć też alias np "pr_a.pole1 as polex" - tego funkcja nie powinna wyciągać.

Czy mogę prosić o pomoc w tym temacie? Potrzebuję to na już a ogarniecie wyrażeń regularnych zajmie mi sporo czasu.
Z góry dziękuję za pomoc.


Go to the top of the page
+Quote Post
Wazniak96
post
Post #2





Grupa: Zarejestrowani
Postów: 550
Pomógł: 75
Dołączył: 5.06.2012
Skąd: Lębork

Ostrzeżenie: (0%)
-----


  1. <?php
  2.  
  3. $test = "SELECT pr_a.pole1, pr_a.pole2, kl_a.pole3, kl_a.pole4 FROM produkty AS pr_a INNER JOIN klienci AS kl_a ON pr_a.pole = kl_a.pol";
  4. preg_match_all("/AS [a-zA-Z_]{4,}/", $test, $matches);
  5. $wynik = str_replace('AS ', '', $matches[0]);
  6. print_r($wynik);


Ten post edytował Wazniak96 25.01.2014, 13:16:49
Go to the top of the page
+Quote Post
kr27
post
Post #3





Grupa: Zarejestrowani
Postów: 27
Pomógł: 0
Dołączył: 20.03.2007

Ostrzeżenie: (0%)
-----


Bardzo dziękuję (IMG:style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 6.10.2025 - 09:52