- Chuyên mục khác :
- Git cơ bản và nâng cao
- ·
- MySQL cơ bản và nâng cao
- ·
- MongoDB cơ bản và nâng cao
- ·
- SQL cơ bản và nâng cao
- ·
- Linux cơ bản và nâng cao
- Học MySQL cơ bản và nâng cao
- Học MySQL cơ bản và nâng cao
- MySQL là gì
- Cài đặt MySQL
- Quản lý MySQL
- Cú pháp kết hợp MySQL và PHP
- Kết nối MySQL
- Tạo Database trong MySQL
- Xóa cơ sở dữ liệu trong MySQL
- Chọn cơ sở dữ liệu trong MySQL
- Kiểu dữ liệu trong MySQL
- Tạo bảng trong MySQL
- Xóa bảng trong MySQL
- Truy vấn INSERT trong MySQL
- Truy vấn SELECT trong MySQL
- Mệnh đề WHERE trong MySQL
- Truy vấn UPDATE trong MySQL
- Truy vấn DELETE trong MySQL
- Mệnh đề LIKE trong MySQL
- Mệnh đề ORDER BY trong MySQL
- Sử dụng JOIN trong MySQL
- Xử lý giá trị NULL trong MySQL
- Regexp trong MySQL
- Transaction trong MySQL
- Lệnh ALTER trong MySQL
- Chỉ mục (INDEX) trong MySQL
- Bảng tạm trong MySQL
- Mô phỏng bảng trong MySQL
- Lấy và sử dụng MySQL Metadata
- Sử dụng Sequence trong MySQL
- Xử lý bản sao trong MySQL
- Injection trong MySQL và SQL
- Export và Phương thức Backup trong MySQL
- Import và phương thức Recovery trong MySQL
- Mệnh đề GROUP BY trong MySQL
- Mệnh đề IN trong MySQL
- Mệnh đề BETWEEN trong MySQL
- Từ khóa UNION trong MySQL
- Hàm hữu ích trong MySQL
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.
Pattern | So khớp với |
---|---|
^ | Phần đầu của chuỗi |
$ | Phần cuối của chuỗi |
. | Bất kỳ ký tự đơn nào |
[...] | Bất kỳ ký tự nào được liệt kê trong dấu ngoặc vuông |
[^...] | Bất kỳ ký tự nào không được liệt kê trong dấu ngoặc vuông |
p1|p2|p3 | Bất kỳ mẫu p1, p2 hoặc p3 nào |
* | 0 hoặc nhiều instance (sự thể hiện) của phần tử ở trước |
+ | 1 hoặc nhiều instance (sự thể hiện) của phần tử ở trước |
{n} | n instance (sự thể hiện) của phần tử ở trước |
{m,n} | Từ m tới n instance (sự thể hiện) của phần tử ở trước |
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ác bài học MySQL phổ biến khác tại s2sontech:
Bình luận (0)