首页 > 数据库技术 > 详细

SQL计算字符串里的子字符串出现个数

时间:2015-07-12 17:22:41      阅读:379      评论:0      收藏:0      [点我收藏+]

在某个页面,需要显示每条记录中有几个图片文件。图片文件名列表存储在mysql表里的photo_files字段,文件名之间用一个空格分开。类似‘images\rpt201503121.jpg images\rpt201503122.jpg images\rpt201503123.jpg‘这样。

mysql的sql语句并不支持正则表达式函数(或者说极其有限),因此最容易想到的是用sql取出来后用PHP的explode函数放到数组里,计算数组元素个数就知道图片文件个数了。但有没有更简单的办法呢?

我的方法是:

select rpt_id,rpt_time,.....,1+length(photo_files)-length(replace(photo_files,‘ ‘,‘‘)) filenum from ........

其实就是把空格换成空字符,计算变化前后的长度差,再+1,即可。这样,就不需要写额外的php代码了。

同样的原理,可以推广到计算子字符串在母字符串里的发生个数(需要做个除法)。

SQL计算字符串里的子字符串出现个数

原文:http://www.cnblogs.com/yingjiang/p/4641139.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!