1

我正在尝试使用 php 从 mysql 中的表中获取单个值或所有值,它适用于单个值,并非所有值都如此,请帮助我。

function displaySitetype() {
    $result = array();
    $result = site_type_find("all");
    print_r($result);
    $count = count($result);
    for ($iter = 0; $iter < $count; $iter++) {
        ?> <option value="<?php echo $iter; ?>"><?php echo $result[$iter]; ?></option> <?php }
}

function site_type_find($site_type) {
    if ($site_type == "all") {
        $result = mysql_query("select * from site_type_table");
        $count = count($result);
        while ($count) {
            $resultarr = mysql_fetch_assoc($result);
            $arr = array_push($arr, $resultarr['site_name']);
            $count--;
        } return $arr;
    } else {
        $result = mysql_query("select site_name from site_type_table where site_id=$site_type");
        $arr = mysql_fetch_array($result);
        return $arr[0];
    }
}
4

1 回答 1

1

最小修复:尝试以下操作(我想您只需要 column 的值site_name

//...
if ($site_type == "all") {
    $result = mysql_query("select site_name from site_type_table");
    $arr = array();
    while ($resultarr = mysql_fetch_assoc($result)) {
        $arr[] = $resultarr['site_name'];
    }
    return $arr;
} else {
//...

顺便说一句,我不建议使用mysql_*函数(在 PHP 5.5+ 中已弃用

请注意,您不能count()直接调用变量 $result (这是对 MySQL 查询结果的引用)。要在您的情况下获得结果计数,您可以使用mysql_num_rows()(仔细检查手册页开头的红色警告框)

于 2013-04-09T12:07:10.437 回答