我在运行代码时遇到以下错误

时间:2012-03-22 08:43:33

标签: php mysql

当我运行此代码时,它向我显示以下错误: -

where子句中的列'virtuemart_product_id'不明确 任何人都可以告诉我如何解决它。 谢谢。

<?php
    mysql_connect('localhost','root','');
    mysql_select_db('joom');
    $get=$_GET['virtuemart_product_id'];
    $get1=$_GET['virtuemart_category_id'];
    $sql="SELECT 
            btn9c_virtuemart_products_en_gb.virtuemart_product_id,
            btn9c_virtuemart_products_en_gb.product_s_desc, 
            btn9c_virtuemart_products_en_gb.product_desc, 
            btn9c_virtuemart_products_en_gb.product_name, 
            btn9c_virtuemart_product_prices.product_price 
          FROM btn9c_virtuemart_products_en_gb 
          JOIN btn9c_virtuemart_product_prices ON
            btn9c_virtuemart_products_en_gb.virtuemart_product_id=btn9c_virtuemart_product_prices.virtuemart_product_id 
          WHERE virtuemart_product_id='$get' ";
    if($result=mysql_query($sql))
    {
        while($row=mysql_fetch_assoc($result))
        {
            echo $row['product_price'];
        }
    }
    else 
    {
        echo (mysql_error());
    }       
?>

3 个答案:

答案 0 :(得分:2)

将表名(或别名)与where子句中的列名放在一起,这些列名在您加入的表之间是通用的。

尝试以下:

$sql="SELECT 
        btn9c_virtuemart_products_en_gb.virtuemart_product_id,
        btn9c_virtuemart_products_en_gb.product_s_desc, 
        btn9c_virtuemart_products_en_gb.product_desc, 
        btn9c_virtuemart_products_en_gb.product_name, 
        btn9c_virtuemart_product_prices.product_price 
      FROM btn9c_virtuemart_products_en_gb 
      JOIN btn9c_virtuemart_product_prices ON
        btn9c_virtuemart_products_en_gb.virtuemart_product_id=btn9c_virtuemart_product_prices.virtuemart_product_id 
      WHERE  btn9c_virtuemart_products_en_gb.virtuemart_product_id='$get' ";

答案 1 :(得分:1)

where子句中,属性virtuemart_product_id未通过表名明确标识。只需在那里使用表格前缀。

SELECT 
  prod.virtuemart_product_id,
  prod.product_s_desc, 
  prod.product_desc, 
  prod.product_name, 
  prices.product_price 
FROM btn9c_virtuemart_products_en_gb prod
JOIN btn9c_virtuemart_product_prices prices ON
  prod.virtuemart_product_id=prices.virtuemart_product_id 
WHERE prod.virtuemart_product_id='$get'

顺便说一下,为表名使用别名。节省大量的打字并使事情更具可读性。

答案 2 :(得分:1)

只需将表名添加到查询的WHERE部分:

..."WHERE table_you_need.virtuemart_product_id='$get' ";