在 MySQL 中,INSTR() 函數可用來決定子字串第一次出現的索引。但是,如果需要確定最後一次出現的索引,則沒有任何內建函數可以輕鬆滿足此要求。
作為替代方法,可以使用 REVERSE() 和 LOCATE() 函數的組合來找出字元或子字串的最後一次出現。此策略包括反轉字串,使用 LOCATE() 識別索引,然後從原始字串的長度中減去結果。
例如,以下語句檢索字串中底線字元的最後一個索引" Have_a_good_day":
SELECT CHAR_LENGTH("Have_a_good_day") - LOCATE('_', REVERSE("Have_a_good_day"))+1;
要擷取最後一次出現分隔符號之前的字串的左側部分,請使用:
SELECT LEFT("first_middle_last", CHAR_LENGTH("first_middle_last") - LOCATE('_', REVERSE("first_middle_last")));
要在最後一次出現分隔符號後隔離字串的右側部分,建議使用SUBSTRING_INDEX() 函數的替代方法:
SELECT SUBSTRING_INDEX("first_middle_last", '_', -1);
雖然LOCATE() 包含從右側搜尋的選項會很方便,但這些技術為取得MySQL 中子字串的最後一個索引提供了有效的解決方案。
以上是如何在 MySQL 中尋找子字串的最後一個索引?的詳細內容。更多資訊請關注PHP中文網其他相關文章!