3

似乎无法从securityinfo场上传递任何东西。

for ($k = 1; $k < $fieldscnt; $k++)
{
    $selectsecurityname = mysql_query("SELECT `security name` FROM securityinfo WHERE symbol = '$symbol[$k]'") or die(mysql_error());
    $securityname = mysql_fetch_array($selectsecurityname);
    $sym = $symbol[$k]

    echo "<td>$securityname[$sym]</td>";
}

基本上,我想在字段中搜索匹配的行,然后从同一行symbol的字段中返回值。securityinfo

4

4 回答 4

4

PHP 对如何在带引号的字符串中使用变量有一些限制。所以你不能像你正在做的那样得到数组元素。

此外,当您将变量插入这样的 SQL 表达式时,您应该确保使用转义。

$selectsecurityname = mysql_query("
    SELECT `security name` FROM securityinfo 
    WHERE symbol = '" . mysql_real_escape_string($symbol[$k]) . "'") 
  or die(mysql_error());

或者,如果这样做更有意义:

$sym = mysql_real_escape_string($symbol[$k]);
$selectsecurityname = mysql_query("
    SELECT `security name` FROM securityinfo 
    WHERE symbol = '{$sym}'") 
  or die(mysql_error());
于 2010-01-17T06:32:40.297 回答
2

$securityname不是立即满阵列。如果您想通过键提取值,我们需要循环遍历每个返回的行并将其添加到我们自己的数组中:

while ($row = mysql_fetch_array($selectsecurityname) {
  $myArray[] = $row;
}

$sym = $symbol[$k];
echo "<td>".$myArray[$sym]."</td>";

有关 的更多信息mysql_fetch_array(),请参阅文档: http: //php.net/manual/en/function.mysql-fetch-array.php

于 2010-01-17T06:30:50.860 回答
0

如果要访问字符串中的数组索引,请将它们括在花括号中:

$a= array(
 'hello'=> 'world',
 'nice'=> 'one',
);

var_dump("This is the value of \$a['hello']: {$a['hello']}");

并将您的原始陈述重写为:

for ($k = 1; $k < $fieldscnt; $k++)
    {
    $selectsecurityname = mysql_query("SELECT `security name` FROM securityinfo WHERE symbol = '{$symbol[$k]}'") or die(mysql_error());
    $securityname = mysql_fetch_array($selectsecurityname);
    $sym = $symbol[$k]

    echo "<td>{$securityname[$sym]}</td>";

当然,您需要确保$symbol[$k]正确转义以在 mysql 语句中使用。

于 2010-01-17T06:49:26.170 回答
0

除了您的示例中其他修复部分的答案之外,还有另一个问题:
您(尝试)从示例中的表中获取一个值。但是当使用它时,您将它作为一个数组访问,而它可能只是一个字符串(一个名称)。

一个完整的例子,所有的东西都是固定的,如下所示:

for ($k = 1; $k < $fieldscnt; $k++)
{
    $sym = mysql_real_escape_string($symbol[$k]);
    $selectsecurityname = mysql_query("SELECT `security name` FROM securityinfo WHERE symbol='$sym'") or die(mysql_error());
    $securitynamearray = mysql_fetch_array($selectsecurityname);
    $securityname = $securitynamearray['security name'];

    echo "<td>$securityname</td>";
}

PS常规变量不需要大括号,所以我省略了它们。

PPS您可以使用mysql_fetch_row代替mysql_fetch_array来防止(最终)您的字段名及其包含的空间出现问题:

$securitynamerow = mysql_fetch_row($selectsecurityname);
$securityname = $securitynamerow[0];
于 2010-01-17T12:03:08.543 回答