我正在研究MYSQL中的一个函数,我有一个逗号分隔的字符串(1,22,344,55)来自另一个表,我怎样才能将它在MYSQL中拆分为一个数组(NOT temp_table).另外,在MYSQL中是否有类似的功能,我可以做foreach()?
Rom*_*nko 11
MySQL不包含拆分分隔字符串的函数.但是,创建自己的功能非常容易.
CREATE FUNCTION SPLIT_STR(
x VARCHAR(255),
delim VARCHAR(12),
pos INT
)
RETURNS VARCHAR(255)
RETURN REPLACE(SUBSTRING(SUBSTRING_INDEX(x, delim, pos),
LENGTH(SUBSTRING_INDEX(x, delim, pos -1)) + 1),
delim, '');
Run Code Online (Sandbox Code Playgroud)
用法
SELECT SPLIT_STR(string, delimiter, position)
Run Code Online (Sandbox Code Playgroud)
从这里:http: //blog.fedecarg.com/2009/02/22/mysql-split-string-function/
小智 5
MySQL中的正确用法是:
SELECT FIND_IN_SET('b','a,b,c,d');
Run Code Online (Sandbox Code Playgroud)
结果为:2
| 归档时间: |
|
| 查看次数: |
30246 次 |
| 最近记录: |