Postgresql: Tìm kiếm với LIKE và ILIKE

nguyen duy
3 min readJul 16, 2018

--

Tôi có 1 bảng actor lưu dữ liệu của các diễn viên điện ảnh với các cột:

  • actor_id PRIMARY KEY integer
  • first_name text
  • last_name text
  • last_update timestamp

Tôi muốn tìm tất cả các diễn viên có first_name là John --> tôi dùng lệnh WHERE với điều kiện first_name = 'John', easy and simple:

SELECT *
FROM actor
WHERE first_name = 'John'
first_name là John

Nhưng, nếu như tôi muốn lấy tất các diễn viên có first_name chứa chữ 'John' ? Tôi không nhớ liệu diễn viên này có first_name là John hay Johnny hay Johnson ?

Trong những trường hợp như này, thay vì dùng operator '=', hãy dùng operator LIKE:

SELECT *
FROM actor
WHERE first_name LIKE '%John%'

trong đó dấu "%" đại diện cho 0 hoặc nhiều kí tự

John, Johnny, Johnson !!!

Như vậy, ```first_name LIKE ‘%John%’``` có thể được hiểu là: first_name có (0 hoặc nhiều) kí tự đứng trước 'John' và có (0 hoặc nhiều) kí tự đứng sau 'John'. Nói cách khác, tất cả những first_name có chứa John

Ngoài operator '%', LIKE còn có thể hoạt động với operator '_':

SELECT *
FROM actor
WHERE first_name LIKE 'Ale_'

Câu lệnh trên sẽ tìm tất cả các diễn viên có first_name bắt đầu với 'Ale', theo sau là duy nhất 1 kí tự bất kì

Alec, Alex, Aley !!!

Thử kết hợp giữa '%' '_' phát nhể ?

SELECT *
FROM actor
WHERE first_name LIKE '_il%'

Hãy tìm cho tôi tất cả các diễn viên có first_name:

  • Chứa chữ 'il'
  • Trước chữ 'il' chỉ có duy nhất 1 kí tự
  • Sau chữ 'il' có bao nhiêu kí tự cũng được
Someone like 'il' !!!

Thế nếu như tôi muốn tìm kiếm không phân biệt hoa/thường ?

Hãy dùng ILIKE (I là viết tắt của case-Insensitive)

SELECT *
FROM actor
WHERE first_name ILIKE '%A%'
ORDER BY first_name

Hãy tìm cho tôi tất cả các diễn viên có first_name chứa chữ cái 'A', không cần biết đó là 'A' in hoa hay 'a' thường

Audrey với 'A' in hoa và Cameron với 'a' thường !!!

Mình mới lập một nhóm có tên là “Cùng học SQL” trên Facebook. Đây là nơi chúng ta chia sẻ kinh nghiệm, giải đáp thắc mắc liên quan đến SQL và database. Các bạn cùng tham gia nhé :D

Link nhóm: https://www.facebook.com/groups/882646945453283/

--

--