15

我正在做一个简单的查询,但它不起作用,我不知道为什么。我最近开始熟悉到数据库的 PDO 连接。

这是代码:

  1. 连接是:

    define("HOST","localhost");
    define("USER","root");
    define("PASS","password");
    define("BASE","portugalforcedb");
    
    
    try{
        $conexao = 'mysql:host='.HOST.';dbname='.BASE;
        $connect = new PDO($conexao, USER, PASS);
        $connect->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    }catch(PDOException $erro){
        echo $erro->getMessage();
    }
    
  2. 然后我创建一个像这样工作的查询:

    try{
        $query = $connect->query("SELECT N.id,N.titulo,N.texto,N.autor,N.data,J.imagem_noticia FROM noticias N JOIN jogo J ON N.jogo_id = J.id WHERE N.publicada =1 ORDER BY N.data DESC LIMIT 4");
    }catch(PDOException $erro){
        echo $erro->getMessage();
    }
    
    while($dados = $query->fetch(PDO::FETCH_ASSOC))
    
    {
    

但后来我在另一个这样的页面中创建了另一个查询,但它不起作用:

$id = $_GET['id'];
    try{
    $query = $connect->prepare("SELECT N.id,N.titulo,N.texto,N.autor,N.data,J.imagem_noticia FROM noticias N JOIN jogo J ON N.jogo_id = J.id WHERE N.publicada =1 AND id=numero");
    $query->bindParam('numero',$id,PDO::PARAM_INT);
    $query->execute();
}catch(PDOException $erro){
    echo $erro->getMessage();
}

$dados = $query->fetch(PDO::FETCH_ASSOC);

我试过了:

$id = $_GET['id'];
    try{
    $query = $connect->query("SELECT N.id,N.titulo,N.texto,N.autor,N.data,J.imagem_noticia FROM noticias N JOIN jogo J ON N.jogo_id = J.id WHERE N.publicada =1 AND id=numero");
}catch(PDOException $erro){
    echo $erro->getMessage();
}

while($dados = $query->fetch(PDO::FETCH_ASSOC))

但随后出现此错误:

SQLSTATE [23000]:违反完整性约束:1052 where 子句中的列 'id' 不明确

4

1 回答 1

38

在查询结束时id=numero。id 需要表别名。它应该是 N.id 或 J.id

于 2013-10-09T13:59:50.240 回答