牛骨文教育服务平台(让学习变的简单)
博文笔记

mysql语句实现php函数explode()的分割字符串功能

创建时间:2012-10-08 投稿人: 浏览次数:2126

首先:arry explode(string $sep,string $string[,int $limit]);函数功能是用指定分隔符$sep把字符串分割成数组。

i.e. 

$string ="手机数码&摄影摄像&滤镜&天马&天马52MM  UV";
$sep = "&";
$arry = explode($sep,$string,5);
print_r($arry);
输出结果:   Array( [0] => 手机数码 [1] => 摄影摄像 [2] => 滤镜 [3] => 天马 [4] => 天马52MM UV)

之所以回想起来要用mysql语句实现它是因为我想把处理后的数组insert 到一个数据库表的相应的字段里去,由于要用到while循环 所以insert的频率很高,服务器跑php有点吃不消,总是提前终止,所以就想用mysql语句代替它。让我们看看mysql语句是如何实现分割功能的:

在这之前要了解到mysql的一个系统函数:SUBSTRING_INDEX(str,delim,count)

返回字符串 str 中在第 count 个出现的分隔符 delim 之前的子串。如果 count 是一个正数,返回从最后的(从左边开始计数)分隔符到左边所有字符。如果 count 是负数,返回从最后的(从右边开始计数)分隔符到右边所有字符。mysql>SELECT SUBSTRING_INDEX("www.baidu.com", ".", 2);-> "www.baidu"mysql> SELECT SUBSTRING_INDEX("www.baidu.com", ".", -2);-> "baidu.com"

实现过程:mysql->

INSERT INTO upcn(uid,pid,cate1,cate2,cate3,cate4,cate5)
  SELECT uid , pid  
  , substring_index(substring_index(cate,"$sepr",1),"$sepr",-1)
  , substring_index(substring_index(cate,"$sepr",2),"$sepr",-1)
  , substring_index(substring_index(cate,"$sepr",3),"$sepr",-1)
  , substring_index(substring_index(cate,"$sepr",4),"$sepr",-1)
  , substring_index(substring_index(cate,"$sepr",5),"$sepr",-1)
  FROM upcm
意思就是分割一次再从后面提取一个子串,其中cata是一个大的字符串由$sep分割开的。cate1..cate5就是cate分割开来的5个子串,分隔符是$sep.

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。