MySQL数据库操作所需的PHP Regex模式

时间:2011-11-17 00:58:18

标签: php regex database denormalized

我的表格中有一些列,说明列包含一些信息,如;

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 

通过正则表达式,但a1b01Value 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
第一部分已更新...

1 个答案:

答案 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]);
}