Đối với điều này, bạn có thể sử dụng SUBSTRING_INDEX (). Đầu tiên chúng ta hãy tạo một bảng -
mysql> create table DemoTable (Number varchar(100)); Query OK, 0 rows affected (0.60 sec)
Ví dụ
Chèn một số bản ghi vào bảng bằng lệnh chèn -
mysql> insert into DemoTable values('235678'); Query OK, 1 row affected (0.20 sec) mysql> insert into DemoTable values('1634990'); Query OK, 1 row affected (0.23 sec) mysql> insert into DemoTable values('678590'); Query OK, 1 row affected (0.46 sec) mysql> insert into DemoTable values('908765432'); Query OK, 1 row affected (0.14 sec) mysql> insert into DemoTable values('222343388773'); Query OK, 1 row affected (0.35 sec) mysql> insert into DemoTable values('09028215'); Query OK, 1 row affected (0.51 sec)
Hiển thị tất cả các bản ghi từ bảng bằng câu lệnh select -
mysql> select *from DemoTable;
Đầu ra
+--------------+ | Number | +--------------+ | 235678 | | 1634990 | | 678590 | | 908765432 | | 222343388773 | | 09028215 | +--------------+ 6 rows in set (0.00 sec)
Sau đây là truy vấn để nhận các giá trị với một số cụ thể trong MySQL -
mysql> select Number from DemoTable where Number LIKE '%5%' ORDER BY LENGTH(SUBSTRING_INDEX(Number, '5', 1));
Đầu ra
+-----------+ | Number | +-----------+ | 235678 | | 678590 | | 908765432 | | 09028215 | +-----------+ 4 rows in set (0.00 sec)