1

我有一个带有逗号分隔的标签名称的字符串,可以插入到 MySQL 表中,例如:

$tags = " 'pigs','dogs','cats' "

我有一个名为tags的 mySQL 表,其中包含tag_id和tag_name

我想将每个标签插入表中。这是否可以在一个使用我拥有的字符串的 INSERT 查询中实现,还是我必须使用一组标签名称运行一个循环?

4

2 回答 2

3

你可以这样做:

$sql = "INSERT INTO `tags` (`tag_name`) VALUES(". implode('),(', explode(',', trim($tags))) . ")";

如果你要回显,$sql你应该得到:

INSERT INTO `tags` (`tag_name`) VALUES('pigs'),('dogs'),('cats')
于 2012-07-11T01:28:59.303 回答
0

这是代码

<?php
$tags = " 'pigs','dogs','cats' ";
$ary_tags = explode(",", trim($tags));
$sql = "INSERT INTO `tags` (`tag_name`) VALUES";
foreach($ary_tags as $t) {
        $sql .= "({$t}),";
}
$sql =  rtrim($sql, ',');
$sql .= ';';
echo $sql;
?>
于 2012-07-11T01:54:39.113 回答