5

我有这部分代码,它给了我标题中的错误。

$k为每张桌子从 1 计数到 5。

$myarray至少包含 3 到 4 个名称。

错误发生在$qu .=...

到目前为止我尝试了什么:将变量名更改$i$v{$i}行中$qu .=

那么有没有可能迭代查询?所以它AND在子句中的 sWHERE与数组的计数一样多?

while ($k<=5) {
  $queryname = "SELECT Name FROM description";
  $qname = mysql_query($queryname,$link);

  while ($reihe = mysql_fetch_object($qname)) {
    {
      $unse = unserialize($reihe->Name);
      {
        foreach ($unse as $j=>$h)
          foreach ($h as $m) {
            $myarray = preg_split('/ |\s| /',$m);
            {
              echo "<br>";
              $array_empty = $myarray;
              $empty_elements = array("");
              $myarray = array_diff($array_empty,$empty_elements);
              var_dump($myarray);
              for ($i=1; $i<=count($myarray); $i++) {
                $v{$i} = $myarray[$i];
                echo $v{$i};
                $esc{$i} = strtolower(mysql_escape_string($v{$i}));
                echo "<br>" . $esc{$i} . "<br>";
                $qu = "SELECT * FROM `table ID=$k` WHERE";
                $qu{$i} .= "AND `table ID=$k`.`name` LIKE '%$esc{$i}%'";
              }
            }
          }
        {
          $test_a = mysql_query($qu,$link) or die (mysql_error());
          echo "<br>";
          var_dump($test_a);
          for ($x=0; $x<mysql_num_rows($test_a); $x++) {
            $row = mysql_result($test_a,$x,'data1');
            $namee = mysql_result($test_a,$x,'data2');
            echo 'data1' . $row . '<br>';
            echo 'data2' . $namee . '<br>';
          }
        }
      }
    }
  }
  $k++;
}
4

1 回答 1

6

您似乎误解了一些基本的 PHP 语法。

手册中所述

字符串s中的字符可以通过使用方数组括号指定字符串后所需字符的从零开始的偏移量来访问和修改,如. 为此,将字符串视为字符数组。当您想要提取或替换超过 1 个字符时,可以使用这些功能。$str[42]substr()substr_replace()

注意: 字符串s 也可以使用大括号访问,如 in $str{42},用于相同目的。

因此,您在整个代码中使用大括号(定义for控制结构范围的除外)是完全错误的,并且不能实现您的意图。

其次,从您的代码看来,您将关系数据存储在序列化的 PHP 对象中;这破坏了使用像 MySQL 这样的 RDBMS 的许多好处。除非您有令人信服的理由不这样做,否则您应该以规范化的形式存储您的 PHP 对象。例如,不是每条description记录都有一个Name包含序列化 PHP 对象的字段,其属性是包含内爆名称字符串的数组,只需将每个这样的名称存储在descriptionNames引用表中相关记录的新表中description

CREATE TABLE descriptionNames (
  descriptionID INT NOT NULL,
  name VARCHAR(50),
  PRIMARY KEY (descriptionId, name),
  FOREIGN KEY (descriptionId) REFERENCES description (descriptionId)
);

您似乎还有五个(示意性地)相同的表,名为Table ID=1,Table ID=2等?如果是这样,您可能应该您的五个表合并为一个,并使用一列(如果需要)来指示记录来自哪个表;我还建议更改您的表名,以避免使用空格等特殊字符,=因为如果您忘记正确引用它们,它们可能只会在以后造成麻烦和混乱。例如:

ALTER TABLE `Table ID=1`
  RENAME TO CombiTable,
  ADD COLUMN FromTableID TINYINT NOT NULL;

UPDATE CombiTable SET FromTableID = 1;

INSERT INTO CombiTable
  SELECT *, 2 FROM `Table ID=2` UNION ALL
  SELECT *, 3 FROM `Table ID=3` UNION ALL
  SELECT *, 4 FROM `Table ID=4` UNION ALL
  SELECT *, 5 FROM `Table ID=5`;

SELECT * FROM CombiTable;  -- check everything is okay

DROP TABLE `Table ID=2`, `Table ID=3`, `Table ID=4`, `Table ID=5`;

无论如何,您不应该使用古老的mysql_*功能。它们不再被维护并且社区已经开始了弃用过程。相反,您应该了解准备好的语句并使用PDO抽象层或改进的MySQLi扩展。

如果您需要维护现有的数据结构,使用 PDO,您可以执行以下操作:

$dbh = new PDO("mysql:dbname=$dbname;charset=utf8", $user, $password);

$qry = $dbh->query("SELECT Name FROM description");
$myarray = array();
while ($reihe = $dbh->fetchColumn())
  foreach (unserialize($reihe) as $h)
    foreach ($h as $m)
      array_merge($myarray, preg_split("/\s+/", $m, -1, PREG_SPLIT_NO_EMPTY));

for ($k = 1; $k <= 5; $k++) {
  $qry = $dbh->prepare("SELECT * FROM `table ID=$k` WHERE " . implode(" OR ",
    array_pad(array(), count($myarray), "name LIKE CONCAT('%', ?, '%')")
  ));

  $qry->execute($myarray);
  while($row = $qry->fetch()) {
    echo "data1:$row[data1]<br/>";
    echo "data2:$row[data2]<br/>";
  }
}

但是,使用我提出的新数据结构,您只需要:

$dbh = new PDO("mysql:dbname=$dbname;charset=utf8", $user, $password);

$qry = $dbh->query("
  SELECT   *
  FROM     CombiTable JOIN descriptionNames USING (name)
  WHERE    FromTableID BETWEEN 1 AND 5   -- in case you have others?
  ORDER BY FromTableID
");

while ($row = $qry->fetch()) {
  echo "data1:$row[data1]<br/>";
  echo "data2:$row[data2]<br/>";
}
于 2012-05-24T18:11:35.230 回答