Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: wyrażenia regularne nie chcą działać
Forum PHP.pl > Forum > Bazy danych > MySQL
sweter
Witam,
mam tabele 'pesele' z dwoma kolumnami:
1. id (int) (autonumerowanie)
2. pasel (varchar)

Próbuję się nauczyć zapytań regularnych i mam taki kod, który ma za zadanie wypisanie wszystkich rekordów:
  1. SELECT * FROM `pesele` WHERE pesel REGEXP '^[:0-9:]{11}$';


niestety pojawia się błąd mówiący
Cytat
Syntax error in SQL expression


Co jest źle?
Dodam, że pisząc polecenia SQL (używam OpenOffice'a) koloruje mi się składnia (słowa kluczowe są niebieskie), jednak w przypadku słówka 'regexp' nie zmienia ono swojej barwy (jest cały czas zielone).

Pozdrawiam smile.gif
vokiel
A czy działa:
  1. SELECT `pasel` FROM `pesele` WHERE `pasel` REGEXP '^[:0-9:]{11}$';
sweter
@up
Niestety nie:(
kitol
a to:

  1. SELECT `pasel` FROM `pesele` WHERE `pasel` REGEXP '^[:digit:]{11}$';
sweter
Wpisanie
[sql]
SELECT `pesel` FROM `pesele` WHERE `pesel` REGEXP '^[:digit:]{11}$'
[/sq]
nadal skutkuje komunikatem
Cytat
Syntax error in SQL expression

sad.gif

// EDIT:
powyższy błąd wywala mi w OpenOffice 3
w phpMyAdminie zwraca mi po prostu
Cytat
MySQL zwrócił pusty wynik (zero rekordów). ( Wykonanie zapytania trwało 0.0010 sekund(y) )

Więc może to jest jakiś błąd w Office?

// EDIT 2:
Okazało się, że OpenOffice nie obsługuje wyrażeni regularnych
No cóż, będę musiał wykonać takie zapytania w Terminalu i później kopiować wyniki...
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.