Mysql
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Mysql

So sánh các chuỗi trong PHP giống như cách MySQL làm

Đối chiếu không liên quan gì đến việc lưu trữ. Bạn cần đặt bộ ký tự để xác định mã hóa lưu trữ. Sự đối chiếu chi phối cách thức so sánh và sắp xếp diễn ra. Đối chiếu phải nhận biết được bộ ký tự, nhưng nếu không thì nó không liên quan gì đến bộ ký tự.

Để trả lời câu hỏi của mình, bạn có thể sử dụng iconv để dịch văn bản, và sau đó so sánh nó. Ví dụ:

function compare($s1, $s2) {
  return strcmp(
    iconv('UTF-8', 'ISO-8859-1//TRANSLIT', $s1),
    iconv('UTF-8', 'ISO-8859-1//TRANSLIT', $s2));
}

Về cơ bản đây là những gì MySql sẽ làm cho bạn, mặc dù nó có thể nhanh hơn và nó có thể có bảng đối chiếu hơi khác so với ISO-8859-1//TRANSLIT . Không hoàn toàn chắc chắn về điều đó.

Tuy nhiên, có lẽ sẽ dễ sử dụng cơ sở dữ liệu hơn như những người khác đã đề xuất.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Rails xây dựng một câu lệnh MySQL như thế nào?

  2. Dữ liệu sẽ được thay thế theo bảng tra cứu

  3. PHP / MySQL:Đánh dấu SOUNDS LIKE kết quả truy vấn

  4. Đã xem lại vấn đề hiệu suất bảng MySQL MyISAM

  5. Chuyển đổi Google map v2 in sang google map v3