0

我目前正在尝试从名为 Merchant 的表中获取数据(M_Name)。

以下是我的代码:

<?php
$response = array();

$link = mysql_connect('localhost','root','') or die ('Could not connect: '.mysql_error());
mysql_select_db('ichop') or die ('Could not connect to database');

$result = mysql_query("select * from offer") or die(mysql_error());

if(mysql_num_rows($result) > 0){
    $response["offers"] = array();

    while($row = mysql_fetch_array($result)){
        $offer = array();
        $offer["offer_id"] = $row["Offer_ID"];
        $offer["start_date"] = $row["Start_Date"];
        $offer["end_date"] = $row["End_Date"];
        $offer["o_desc"] = $row["O_Desc"];
        $offer["short_desc"] = $row["Short_Desc"];
        $offer["merchant_ID"] = $row["Merchant_ID"];
        $offer["m_name"] = mysql_query("SELECT M_Name FROM MERCHANT WHERE MERCHANT_ID = '".$row["merchant_ID"]."'");

        array_push($response["offers"], $offer);
    }
    $response["success"] = 1;

    echo json_encode($response);
} else {
//no offer found
$response["success"] = 0;
$response["message"] = "No offer found";

echo json_encode($response);
}
?>

当我使用 Web 浏览器运行此 PHP 文件时,即使数据库中存在数据,我也无法获得所需的商家名称......它只会返回“null”。

{"offers":[{"offer_id":"1","start_date":"2013-05-17","end_date":"2013-05-18","o_desc":"AAA","merchant_ID":"2","m_name":null}],"success":1}

我做错了什么或者我还缺少什么?请帮助..谢谢!

4

5 回答 5

0

mysql_query("SELECT M_Name FROM MERCHANT WHERE MERCHANT_ID = '".$row["merchant_ID"]."'");不会从数据库返回值,您需要跟进它,例如您mysql_fetch_array对数据库的其他查询所做的那样。

有一个更简单的解决方案:使用 a JOIN,它结合了两个表。

SELECT offer.*, MERCHANT.M_Name 
FROM offer 
LEFT JOIN MERCHANT ON(MERCHANT.MERCHANT_ID = offer.merchant_ID)
于 2013-05-17T08:14:09.833 回答
0

看起来你必须从查询中返回结果而不是 while,

mysql_fetch_array(mysql_query("SELECT M_Name FROM MERCHANT WHERE MERCHANT_ID = '".$row["merchant_ID"]."'"));

但最好你先犯一些错误

于 2013-05-17T08:17:26.330 回答
0

您可以使用以下一种

$resMerchant = mysql_query("SELECT M_Name FROM MERCHANT WHERE MERCHANT_ID = '".$row["merchant_ID"]."'");

$rowMerchant = mysql_fetch_assoc($resMerchant);
$offer["m_name"] = $rowMerchant['M_Name'];
于 2013-05-17T08:18:06.527 回答
0

我宁愿使用LEFT JOINmysql 函数并在第一次查询时从你的两个表中获取所有相关数据

 SELECT * FROM offer a LEFT JOIN MERCHANT b ON a.Merchant_ID = b.MERCHANT_ID

所以你不必做任何额外的查询,你可以将你的值直接存储在你的数组中

$offer["m_name"] = $row['M_Name'];

然后我希望您记住这些mysql_*功能已被弃用,因此我建议您切换到mysqliPDO

于 2013-05-17T08:18:13.293 回答
0
$offer["m_name"] = mysql_query("SELECT M_Name FROM MERCHANT WHERE MERCHANT_ID = '".$row["merchant_ID"]."'")

mysql_query()不返回字符串而是资源。您必须获取结果。

另外,不要忘记 mysql_* 现在已弃用。

[编辑]

正如 Fabio 所说,您宁愿在查询中使用 JOIN 。目前,您正在循环中发出请求。这是没用的(INNER JOIN 或 LEFT JOIN 是你想要的)并且非常消耗资源。

于 2013-05-17T08:14:57.307 回答