分割字符串為數(shù)組需要用到 三個(gè)mysql 的函數(shù) :
REVERSE(str) 返回顛倒字符順序的字符串str。
SUBSTRING_INDEX(str,delim,count)
返回從字符串str的第count個(gè)出現(xiàn)的分隔符delim之后的子串。如果count是正數(shù),返回最后的分隔符到左邊(從左邊數(shù)) 的所有字符。如果count是負(fù)數(shù),返回最后的分隔符到右邊的所有字符(從右邊數(shù))。
REPLACE(str,from_str,to_str)
返回字符串str,其字符串from_str的所有出現(xiàn)由字符串to_str代替。
通過三個(gè)函數(shù)的組合使用做到分割字符串為數(shù)組的功能。
首先寫兩個(gè)函數(shù)
1,獲得所有以“某個(gè)符號“分割的字符串的個(gè)數(shù),函數(shù)內(nèi)容如下
(將sql代碼復(fù)制放在navicat中執(zhí)行即可)
DELIMITER $$
CREATE DEFINER=`root`@`%` FUNCTION `func_get_split_string_total`(
f_string varchar(1000),f_delimiter varchar(5)
) RETURNS int(11)
BEGIN
-- Get the total number of given string.
return 1+(length(f_string) - length(replace(f_string,f_delimiter,'')));
END$$
DELIMITER ;
2、按分割取出字符串
(將sql代碼復(fù)制放在navicat中執(zhí)行即可)
DELIMITER $$
CREATE DEFINER=`root`@`%` FUNCTION `func_get_split_string`(
f_string varchar(1000),f_delimiter varchar(5),f_order int) RETURNS varchar(255) CHARSET utf8
BEGIN
-- Get the separated number of given string.
declare result varchar(255) default '';
set result = reverse(substring_index(reverse(substring_index(f_string,f_delimiter,f_order)),f_delimiter,1));
return result;
END$$
DELIMITER ;
然后再寫一個(gè)存儲過程進(jìn)行組合使用這兩個(gè)函數(shù),輸入需要分割的字符串 ,和分隔符,輸出 按某某符號分割后的數(shù)組
(將sql代碼復(fù)制放在navicat中執(zhí)行即可)
DELIMITER $$
CREATE PROCEDURE `sp_print_result`(
IN f_string varchar(1000),IN f_delimiter varchar(5)
)
BEGIN
-- Get the separated string.
declare cnt int default 0;
declare i int default 0;
set cnt = func_get_split_string_total(f_string,f_delimiter);
drop table if exists tmp_print;
create temporary table tmp_print (num int not null);
while i cnt
do
set i = i + 1;
insert into tmp_print(num) values (func_get_split_string(f_string,f_delimiter,i));
end while;
select * from tmp_print;
END$$
DELIMITER ;
然后輸入字符串進(jìn)行測試。
call sp_print_result(“434,123,12,234,123,123”,”,”);
結(jié)果如下圖
可能執(zhí)行的時(shí)候會(huì)報(bào)錯(cuò):The user specified as a definer (‘root'@'%') does not exist
解決方法如下:
執(zhí)行 :grant all privileges on *.* to root@"%" identified by ".";
執(zhí)行 :flush privileges;
就解決了這個(gè)問題。
最后說一下存儲過程和mysql的函數(shù)
存儲過程是用戶定義的一系列sql語句的集合,涉及特定表或其它對象的任務(wù),用戶可以調(diào)用存儲過程,而函數(shù)通常是數(shù)據(jù)庫已定義的方法,它接收參數(shù)并返回某種類型的值并且不涉及特定用戶表。
存儲過程和函數(shù)存在以下幾個(gè)區(qū)別:
1)一般來說,存儲過程實(shí)現(xiàn)的功能要復(fù)雜一點(diǎn),而函數(shù)的實(shí)現(xiàn)的功能針對性比較強(qiáng)。存儲過程,功能強(qiáng)大,可以執(zhí)行包括修改表等一系列數(shù)據(jù)庫操作;用戶定義函數(shù)不能用于執(zhí)行一組修改全局?jǐn)?shù)據(jù)庫狀態(tài)的操作。
2)對于存儲過程來說可以返回參數(shù),如記錄集,而函數(shù)只能返回值或者表對象。函數(shù)只能返回一個(gè)變量;而存儲過程可以返回多個(gè)。存儲過程的參數(shù)可以有IN,OUT,INOUT三種類型,而函數(shù)只能有IN類~~存儲過程聲明時(shí)不需要返回類型,而函數(shù)聲明時(shí)需要描述返回類型,且函數(shù)體中必須包含一個(gè)有效的RETURN語句。
3)存儲過程,可以使用非確定函數(shù),不允許在用戶定義函數(shù)主體中內(nèi)置非確定函數(shù)。
4)存儲過程一般是作為一個(gè)獨(dú)立的部分來執(zhí)行( EXECUTE 語句執(zhí)行),而函數(shù)可以作為查詢語句的一個(gè)部分來調(diào)用(SELECT調(diào)用),由于函數(shù)可以返回一個(gè)表對象,因此它可以在查詢語句中位于FROM關(guān)鍵字的后面。 SQL語句中不可用存儲過程,而可以使用函數(shù)。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
您可能感興趣的文章:- Mysql字符串截取及獲取指定字符串中的數(shù)據(jù)
- MySQL截取和拆分字符串函數(shù)用法示例
- MySQL 字符串拆分操作(含分隔符的字符串截取)