首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将逗号分隔的mysql标记与数据库值进行匹配(WP - PHP)

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

Stack Overflow用户
提问于 2011-03-10 23:59:12
回答 2查看 760关注 0票数 0
代码语言:javascript
复制
$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命令进行优化或代码更少)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-03-11 00:04:12

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

真的很简单:

代码语言:javascript
复制
<?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;
票数 2
EN

Stack Overflow用户

发布于 2011-03-11 00:04:07

看一下FIND_IN_SET函数。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5262254

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档