我的表格中有一些列,说明列包含一些信息,如;
a1b01,Value 1,2,1,60|a1b01,Value2,1,1,50|b203c,Value 1,0,2,20
使用SQL命令,我需要更新它。
在那里,如果第一个和第二个参数存在于当前记录中(在描述列中),我将使用PHP函数进行更新。
例如:如果用户想要更改包含a1b01,Value 1
的描述值,我将执行类似的SQL命令;
function do_action ($code,$value,$new1,$new2,$newresult) {
UPDATE the_table SET descriptions = REPLACE(descriptions, $code.','.$value.'*', $code.','.$value.','.$new1.','.$new2.','.$newresult)";
}
我的问题是:我怎么能
a1b01,Value 1,2,1,60|
部分来自下面的字符串
a1b01,Value 1,2,1,60|a1b01,Value2,1,1,50|b203c,Value 1,0,2,20
通过正则表达式,但a1b01
和Value 1
应该作为参数获取。
我只想要那个;当我这样打do_action
时;
do_action ("a1b01","Value 1",2,3,25);
记录将是: a1b01,Value 1,2,3,25
|a1b01,Value2,1,1,50|b203c,Value 1,0,2,20
(第一部分已更新... )
答案 0 :(得分:1)
您不一定需要使用正则表达式来执行此操作,您可以使用explode函数,因为它已全部分隔
所以你可以这样做:
$descriptionArray = explode('|', $descriptions); //creates array of the a1b01,Value 1,2,1,60 block
//then for each description explode on ,
for($i = 0; i < count($descriptionArray); $i++){
$parameters = explode(',', $descriptionArray[$i]);
do_action ($parameters[0],$parameters[1],$parameters[2],$parameters[3],$parameters[4]);
}