0

我的表中有一些列,描述列包含一些信息,例如;

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

4

1 回答 1

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]);
} 
于 2011-11-17T01:18:32.240 回答