Sử dụng phương thức LOCATE () và SUBSTRING () cho việc này trong MySQL. Đầu tiên chúng ta hãy tạo một bảng -
mysql> create table DemoTable -> ( -> Title text -> ); Query OK, 0 rows affected (0.54 sec)
Chèn một số bản ghi vào bảng bằng lệnh chèn -
mysql> insert into DemoTable values('Introduction To Java');
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable values('Introduction - To MySQL');
Query OK, 1 row affected (0.16 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
Điều này sẽ tạo ra kết quả sau -
+-------------------------+ | Title | +-------------------------+ | Introduction To Java | | Introduction - To MySQL | +-------------------------+ 2 rows in set (0.00 sec)
Sau đây là truy vấn để hiển thị một chuỗi con trước một ký tự đặc biệt trong một chuỗi con -
mysql> select distinct
-> if(LOCATE(' - ',Title)>0, SUBSTRING(Title, 1, LOCATE(' - ', Title)), Title) from DemoTable; Đầu ra
Điều này sẽ tạo ra kết quả sau -
+-----------------------------------------------------------------------------+
| if(LOCATE(' - ',Title)>0, SUBSTRING(Title, 1, LOCATE(' - ', Title)), Title) |
+-----------------------------------------------------------------------------+
| Introduction To Java |
| Introduction |
+-----------------------------------------------------------------------------+
2 rows in set (0.00 sec)