Соответствие разделенных запятыми тегов mysql значениям базы данных (WP - PHP) - PullRequest
0 голосов
/ 10 марта 2011
$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;
  }
}

Это мой рабочий код. Это работает, но мне действительно не нравится иметь команду SQL в foreach. Я предположил, что это не будет проблемой, поскольку на каждой странице не более 8 тегов. Есть ли более эффективный способ закодировать это? (т.е. оптимизировать для 1 команды mysql или иметь меньше кода)

Ответы [ 2 ]

2 голосов
/ 10 марта 2011

Это мой рабочий код. Это работает, но мне действительно не нравится иметь команду SQL в foreach. Я предположил, что это не будет проблемой, поскольку на каждой странице не более 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;
0 голосов
/ 10 марта 2011

Посмотрите на функцию FIND_IN_SET .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...