警告:mysql_fetch_row()期望参数1是资源

时间:2011-08-18 19:54:06

标签: php mysql

  

可能重复:
  mysql_fetch_array() expects parameter 1 to be resource, boolean given in select

运行此脚本时收到以下消息:

警告:mysql_fetch_row()期望参数1是资源,第12行的/var/www/html/toolkit/routing.php中给出了字符串

我在mysql控制台中运行了查询并打印了正确的行。不知道为什么我不能让它出现在PHP?

routing.php页面:

<?php
error_reporting(E_ALL);
////error_reporting(0);
ini_set('display_errors', 'On');
include("db/sbc_config.php");
include("db/mysql.class.php");
$db = new MySQL(true, DB_DATABASE_ROUTING, DB_SERVER, DB_USER , DB_PASS);
if ($db->Error()) $db->Kill();

        $searchroute = "SELECT * FROM destination_route as d WHERE d.destPrefix='2146811'";

        $result = mysql_fetch_row($searchroute);
    echo $result;

    ?>

sbc_config.php:

<?php
//database server
define('DB_SERVER', "10.10.1.146");

//database login name"
define('DB_USER', "user");

//database login password
define('DB_PASS', "pasword");

//database names
define('DB_DATABASE_ROUTING', "routing");

//smart to define your table names also
define('TABLE_DESTINATION_ROUTE', "destination_route");


?>

4 个答案:

答案 0 :(得分:7)

mysql_fetch_row接受游标并返回该游标中的下一行。你想给它一个字符串。你错过了一步。

您必须先执行该查询:

$cursor = mysql_query($searchroute); // for example
$result = mysql_fetch_row($cursor); 

答案 1 :(得分:2)

您必须先执行查询才能获取结果:

$searchroute = "SELECT *  ...";
$results = mysql_query($searchroute);
$row = mysql_fetch_row($results);

答案 2 :(得分:0)

必须在mysql_query之后调用mysql_fetch_row,你不能将查询传递给fetch行   - 见PHP Manual

答案 3 :(得分:0)

$db = new MySQL(true, DB_DATABASE_ROUTING, DB_SERVER, DB_USER , DB_PASS);

应该是MySQLi吗? mysql _ *()函数没有OOP接口。你将mise mysqli和mysql调用,这是不受支持的。它们在内部完全相互独立,而另一个的db句柄或结果语句在另一个中是不可用的。