$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;
}
}这是我的工作代码。它可以工作,但我真的不喜欢在foreach中使用SQL命令。我认为这不是问题,因为在任何给定的页面上都不会超过8个标签。有没有更有效的方式来编码呢?(例如,针对1个mysql命令进行优化或代码更少)
发布于 2011-03-11 00:04:12
这是我的工作代码。它可以工作,但我真的不喜欢在foreach中使用SQL命令。我认为这不是问题,因为在任何给定的页面上都不会超过8个标签。有没有更有效的方式来编码呢?(例如,针对1个mysql命令进行优化或代码更少)
真的很简单:
<?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;发布于 2011-03-11 00:04:07
看一下FIND_IN_SET函数。
https://stackoverflow.com/questions/5262254
复制相似问题