mysql_fetch_row就是返回一个$arrRow[0]这种数组,
要达到你的效果,得用mysql_fetch_assoc
<?php$conn = mysql_connect("localhost", "mysql_user", "mysql_password");if (!$conn) {
    echo "Unable to connect to DB: " . mysql_error();
    exit;
}if (!mysql_select_db("mydbname")) {
    echo "Unable to select mydbname: " . mysql_error();
    exit;
}$sql = "SELECT id as userid, fullname, userstatus
        FROM   sometable
        WHERE  userstatus = 1";$result = mysql_query($sql);if (!$result) {
    echo "Could not successfully run query ($sql) from DB: " . mysql_error();
    exit;
}if (mysql_num_rows($result) == 0) {
    echo "No rows found, nothing to print so am exiting";
    exit;
}while ($row = mysql_fetch_assoc($result)) {
    echo $row["userid"];
    echo $row["fullname"];
    echo $row["userstatus"];
}mysql_free_result($result);?>

解决方案 »

  1. echo $arrRow['id'];如果用字段名索引,要按上面的用,如果用数字索引$arrRow[0]
      

  2. mysql_fetch_array
    (PHP 3, PHP 4 , PHP 5)mysql_fetch_array --  从结果集中取得一行作为关联数组,或数字数组,或二者兼有 
    说明
    array mysql_fetch_array ( resource result [, int result_type])
    返回根据从结果集取得的行生成的数组,如果没有更多行则返回 FALSE。 mysql_fetch_array() 是 mysql_fetch_row() 的扩展版本。除了将数据以数字索引方式储存在数组中之外,还可以将数据作为关联索引储存,用字段名作为键名。 如果结果中的两个或以上的列具有相同字段名,最后一列将优先。要访问同名的其它列,必须用该列的数字索引或给该列起个别名。对有别名的列,不能再用原来的列名访问其内容(本例中的 'field')。 例子 1. 相同字段名的查询select table1.field as foo, table2.field as bar from table1, table2
     
     
    有一点很重要必须指出,用 mysql_fetch_array() 并不明显 比用 mysql_fetch_row() 慢,而且还提供了明显更多的值。 mysql_fetch_array() 中可选的第二个参数 result_type 是一个常量,可以接受以下值:MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。本特性是 PHP 3.0.7 起新加的。本参数的默认值是 MYSQL_BOTH。 如果用了 MYSQL_BOTH,将得到一个同时包含关联和数字索引的数组。用 MYSQL_ASSOC 只得到关联索引(如同 mysql_fetch_assoc() 那样),用 MYSQL_NUM 只得到数字索引(如同 mysql_fetch_row() 那样)。 注: 该函数返回的字段名是大小写敏感的。例子 2. mysql_fetch_array 使用 MYSQL_NUM<?php
        mysql_connect("localhost", "mysql_user", "mysql_password") or
            die("Could not connect: " . mysql_error());
        mysql_select_db("mydb");    $result = mysql_query("SELECT id, name FROM mytable");    while ($row = mysql_fetch_array($result, MYSQL_NUM)) {
            printf ("ID: %s  Name: %s", $row[0], $row[1]);
        }    mysql_free_result($result);
    ?>  
     
    例子 3. mysql_fetch_array 使用 MYSQL_ASSOC<?php
        mysql_connect("localhost", "mysql_user", "mysql_password") or
            die("Could not connect: " . mysql_error());
        mysql_select_db("mydb");    $result = mysql_query("SELECT id, name FROM mytable");    while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) {
            printf ("ID: %s  Name: %s", $row["id"], $row["name"]);
        }    mysql_free_result($result);
    ?>  
     
    例子 4. mysql_fetch_array 使用 MYSQL_BOTH<?php
        mysql_connect("localhost", "mysql_user", "mysql_password") or
            die("Could not connect: " . mysql_error());
        mysql_select_db("mydb");    $result = mysql_query("SELECT id, name FROM mytable");    while ($row = mysql_fetch_array($result, MYSQL_BOTH)) {
            printf ("ID: %s  Name: %s", $row[0], $row["name"]);
        }    mysql_free_result($result);
    ?>  
     
    参见 mysql_fetch_row() 和 mysql_fetch_assoc()。  
     
      

  3. 对头,应该用mysql_fetch_assoc,建议不用要mysql_fetch_row 
      

  4. 解决了,结果里汉字成了 ?? 是编码的问题吧
    PHP里那些设置编码的?
    今天才接触PHP,以前学过.net,向大家请教。
      

  5. 编码问题你要知道你保存数据是什么格式编码的。
    取数据之前 set names 'gbk'或者相应编码格式
      

类似问题 »