[英]update table column of every row in mysql
我在sql中有一个表,该表有3列,分别名为id
, title
和story_url
。
我试图使SEO friendly URL
。 所以我想做的是使用title
并将white spaces
和special chars
replace
为dash(-)并将其保存到其他column story_url
。 story_url是空的atm。
更新我所有的表行,或将创建的url插入story_url
。
如果我在while循环中执行此操作,则它只会在所有行中添加一个最后一个值。
function seoUrl($string) {
$string = strtolower($string);
$string = preg_replace("/[^a-z0-9_\s-]/", "", $string);
$string = preg_replace("/[\s-]+/", " ", $string);
$string = preg_replace("/[\s_]/", "-", $string);
return $string;
}
while($row = mysqli_fetch_array($run)) {
$title = $row['title'];
$story = $row['story'];
$id = $row['id'];
$url = seoUrl($title);
$query = "UPDATE table SET story_url='$url'";
mysqli_query($conn,$query);
}
您的UPDATE
查询需要具有WHERE
子句。
将查询替换为以下内容:
$query = "UPDATE table SET story_url='$url' WHERE id='$id'";
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.