Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Wyrażenie regularne generowane przez php dla bazy MySQL, istotna kolejnosc znakow
elmozaur
post
Post #1





Grupa: Zarejestrowani
Postów: 518
Pomógł: 18
Dołączył: 21.07.2008

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


Witajcie.
Glowie sie nad tym problemem od jakiegos czasu i nie wiem jak to wymyslic. Chcialbym dodac nowa funkcjonalnosc do swojej strony, ktora polegala by na nadawaniu cech indywidualnych newsom lub tresci. Na poczatek wymyslilem ze cechy bede zapisywal binarnie w formacie 5 znakow (0 lub 1).Strona jest o dzielach sztuki a cechy zapisuje tak:
cecha_malarz=10000, cecha_grafik=01000, cecha_fotograf=00100, cecha_malarz_grafik=11000, cecha_wszystko=11100. Taka cecha zapisywana jest razem z newsem dla ulatwienia wyszukiwania.

I teraz moje pytanie:
jak zadac pytanie do bazy (mysle ze za pomoca wyrazenia regularnego) ktore bedzie poprawnie interpretowalo takie cechy.Np jesli dam pytanie o newsy ktore spelniaja cechy malarstwa (10000) to chcialbym otrzymac w wyniku zarowno malarza(10000) jak rowniez malarza_grafika(11000) i wszystko(11100).

Domyslam sie ze chodzi o jakies przerobienie zapisu 10000 na cos takiego : na pozycji pierwszen ma byc jedynka a na pozostalych obojetnie co.
lub w przypadku 00110 : na pozycji trzeciej i czwartej musi byc 1 a na pozostalych obojetnie

tylko jak to zapisac wyrazeniem regularnym ?

za kazda podpowiedz dziekuje i pozdrawiam
G
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
nospor
post
Post #2





Grupa: Moderatorzy
Postów: 36 559
Pomógł: 6315
Dołączył: 27.12.2004




Pomysl miales dobry ale z wykonaniem przekombinowales.
Owszem, mają to byc zapisy binarne ale nie jako cyferki 01 ale jako bity.

malarz - 1 bitowo to bedzie: 001
grafik - 2 bitowo to bedzie: 010
fotograf - 4 bitowo to bedzie: 100

no i teraz laczenie bitowe or:
malarz grafik 1 | 2 = 3 bitowo to bedzie: 011
grafik fotograf 2 | 4 = 6 bitowo to bedzie: 110
malarz grafik fotograf 1|2|4 = 7 bitowo to bedzie: 111

Jak chcesz w zapytaniu znaleźć w zapytaniu grafika to robisz:
  1. SELECT * FROM tabela WHERE cecha & 2

fotografa:
  1. SELECT * FROM tabela WHERE cecha & 4

Proste, lekkie i przejemne (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

edit: rozwiązanie to ma jeszcze jedną zalete. Twoj zapis 5 cyfr zajmowal by 5 bajtow. Moje rozwiązanie zajmuje tylko jeden bajt. Pięciokrotne zaoszczedzenie miejsca (IMG:http://forum.php.pl/style_emoticons/default/winksmiley.jpg)
Go to the top of the page
+Quote Post

Posty w temacie


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: 9.10.2025 - 16:18