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)