Hướng dẫn dùng regexp sql trong PHP
Regexp trong MySQL - Biểu thức chính quy trong MySQL. Bạn đã thấy MySQL sử dụng câu lệnh có dạng (Pattern Matching) LIKE …%. MySQL cũng hỗ trợ hoạt động so khớp mẫu khác dựa trên biểu thức chính quy và toán tử REGEXP. Nếu bạn đã sử dụng Regex trong Java, thì nó là khá đơn giản để bạn hiểu về hoạt động này bởi vì việc so khớp này là khá tương tự như
các biểu thức chính quy trong các ngôn ngữ lập trình Java. Bảng dưới liệt kê các Pattern có thể được sử dụng cùng với toán tử REGEXP. Dựa vào bảng trên, bạn có thể thành lập nhiều kiểu truy vấn SQL đa dạng tùy theo yêu cầu của bạn. Ở đây, mình sẽ liệt kê một số kiểu cần thiết nhất. Giả sử chúng ta có một bảng sinhvienk60 và có một trường là ten: Truy vấn để tìm tất cả NAME bắt đầu với '^Ng': Truy vấn để tìm tất cả NAME kết thúc với 'ng$': SELECT name FROM nhanvien WHERE ten REGEXP 'ng$'; Truy vấn để tìm tất cả NAME chứa 'ao': SELECT name FROM nhanvien WHERE ten REGEXP 'ao'; Truy vấn để tìm tất cả NAME bắt đầu với một nguyên âm và kết thúc với 'nh': SELECT name FROM nhanvien WHERE ten REGEXP '^[aeiou]|nh$'; Bạn đã thấy cách MySQL so khớp mẫu (Pattern Matching) với LIKE …%. MySQL hỗ trợ hoạt động so khớp mẫu khác dựa trên Regular Expression và toán tử REGEXP. Nếu bạn đã hiểu về PHP hoặc PERL, thì nó là khá đơn giản để bạn hiểu về hoạt động này bởi vì việc so khớp này là khá tương tự như các Regular Expression trong các ngôn ngữ đó. Bảng dưới liệt kê các Pattern có thể được sử dụng cùng với toán tử REGEXP.
Quảng cáo Ví dụDựa vào bảng trên, bạn có thể thành lập nhiều kiểu truy vấn SQL đa dạng tùy theo yêu cầu của bạn. Ở đây, mình sẽ liệt kê một số kiểu cần thiết nhất. Giả sử chúng ta có một bảng sinhvienk60 và có một trường là ten: Truy vấn để tìm tất cả ten bắt đầu với '^Ng': SELECT ten FROM sinhvienk60 WHERE ten REGEXP '^Ng'; Truy vấn để tìm tất cả ten kết thúc với 'ng$': SELECT ten FROM sinhvienk60 WHERE ten REGEXP 'ng$'; Truy vấn để tìm tất cả ten chứa 'ao': SELECT ten FROM sinhvienk60 WHERE ten REGEXP 'ao'; Truy vấn để tìm tất cả ten bắt đầu với một nguyên âm và kết thúc với 'nh': SELECT ten FROM sinhvienk60 WHERE ten REGEXP '^[aeiou]|nh$'; Đã có app VietJack trên điện thoại, giải bài tập SGK, SBT Soạn văn, Văn mẫu, Thi online, Bài giảng....miễn phí. Tải ngay ứng dụng trên Android và iOS. Theo dõi chúng tôi miễn phí trên mạng xã hội facebook và youtube: Follow fanpage của team https://www.facebook.com/vietjackteam/ hoặc facebook cá nhân Nguyễn Thanh Tuyền https://www.facebook.com/tuyen.vietjack để tiếp tục theo dõi các loạt bài mới nhất về Java,C,C++,Javascript,HTML,Python,Database,Mobile.... mới nhất của chúng tôi. Các bài học MySQL phổ biến khác tại VietJack:
Bài viết liên quan
|