将逗号分隔的mysql标记与数据库值匹配(WP-PHP)

将逗号分隔的mysql标记与数据库值匹配(WP-PHP),php,mysql,wordpress,Php,Mysql,Wordpress,这是我的工作代码。它可以工作,但我真的不喜欢在foreach中使用SQL命令。我认为这不会是一个问题,因为任何给定页面上的标签不超过8个。有没有更有效的方法来编写代码?(即优化1个mysql命令或减少代码)看看函数 这是我的工作代码。它可以工作,但我真的不喜欢在foreach中使用SQL命令。我认为这不会是一个问题,因为任何给定页面上的标签不超过8个。有没有更有效的方法来编写代码?(即优化1个mysql命令或代码更少) 其实很简单: $tagList = get_the_tag_list('',

这是我的工作代码。它可以工作,但我真的不喜欢在foreach中使用SQL命令。我认为这不会是一个问题,因为任何给定页面上的标签不超过8个。有没有更有效的方法来编写代码?(即优化1个mysql命令或减少代码)

看看函数

这是我的工作代码。它可以工作,但我真的不喜欢在foreach中使用SQL命令。我认为这不会是一个问题,因为任何给定页面上的标签不超过8个。有没有更有效的方法来编写代码?(即优化1个mysql命令或代码更少)

其实很简单:

$tagList = get_the_tag_list('','---','');
$totaltags = explode('---',$tagList);
foreach ($alltags AS $eachtag)
{
  $thistag = GetBetween($eachtag,'/tag/','/');
  $SQL = "SELECT * FROM table WHERE thetag = '$eachtag'"
  $result = mysql_query($SQL, $link) or die(mysql_error());  
  if(mysql_affected_rows()>0)
  {
     echo $thistag;
  }
}

<?php
// build quotes around the tags, this specific syntax is PHP 5.3+
$alltags = array_map( $alltags, function( $value ) { 
    return "'" . mysql_real_escape_string( $value ) . "'";
});

$query = 'SELECT * FROM table WHERE thetag IN ( %s );';
$sql = sprintf( $query, implode( ', ', $alltags ) );
echo $sql;