数组数据类型,拆分字符串,

时间:2010-11-02 14:50:36

标签: mysql

我正在使用MYSQL中的函数,我有另一个表中的逗号分隔字符串(1,22,344,55),如何将它在MYSQL中拆分为数组(NOT temp_table)。另外,在MYSQL中是否有类似的功能,我可以做foreach()?

3 个答案:

答案 0 :(得分: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, '');

用法

SELECT SPLIT_STR(string, delimiter, position)

从这里: http://blog.fedecarg.com/2009/02/22/mysql-split-string-function/

答案 1 :(得分:5)

MySQL中的正确用法是:

SELECT FIND_IN_SET('b','a,b,c,d');

结果如下:2

答案 2 :(得分:1)

SQL的foreach版本称为cursor