Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: join po fragmencie tekstu w innej kolumnie
Forum PHP.pl > Forum > Bazy danych > MySQL
niewiemjak
mam tabelę nr 1...
  1. id | kod | reszta

i tabelę nr 2
  1. id_mail | tytul | tresc | email

muszę wyciągnąć email z tabeli 2 dla kodów w tabeli 1
kod jest w treści maila - w php da się to wyciągnąć bez problemów,
Pyt czy nie da się tego wyciągnąć czystym mysql?

nie ma niczego pośredniego, ani innych powiązań między tabelami...

czyli szukam czegoś co zadziała w stylu
  1. SELECT kod, email FROM tab1 t1
  2. LEFT JOIN tab2 t2 ON (t2.tresc LIKE '%t1.`kod`%')

wiem, że w tej postaci nie zadziała...
trueblue
Musi to być LEFT JOIN?
Jeśli nie, to po prostu przenieś warunek złączenia do WHERE.
mmmmmmm
http://sqlfiddle.com/#!9/94e9a8/3
niewiemjak
dzięki,
musiało być złączenie - bo jak inaczej wyciągniesz zawartość kolumny z drugiej tabeli?
trueblue
Tak:
  1. SELECT t1.kod, t1.email, t2.* FROM tab1 AS t1, tab2 AS t2 WHERE t2.tresc LIKE CONCAT('%',t1.kod,'%')
niewiemjak
Dzięki, zapomniałam, że można robić from z więcej niż 1 tabeli (daawno z taką konstrukcją się nie spotkałam) ;-)
chociaż pewnie zbyt optymalne to nie jest.

Ale ogólnie ta baza na której pracuję jest średnio optymalna...
trueblue
Równie optymalne jak złączenie na takim warunku.
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.