dongtuoleng8624 2015-07-20 23:57
浏览 43
已采纳

PHP PDO致命错误 - 未找到列但我不看[关闭]

For some reason I'm getting this error, but I'm not lookin for a column named aaron.

Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[42S22]: Column not found: 1054 Unknown column 'Aaron' in 'field list'' in /home/stretch045/public_html/scripts/auth.php:15 Stack trace: #0 /home/stretch045/public_html/scripts/auth.php(15): PDO->prepare('INSERT INTO use...') #1 /home/stretch045/public_html/index.php(35): Auth->checkToken('94257b73ea4ed51...') #2 {main} thrown in /home/stretch045/public_html/scripts/auth.php on line 15

CODE:

$conn = $this->db;
$stmt = $conn->prepare("UPDATE users SET rating='".$xml->rating."', atc='".$xml->ratingatc."', pilot='".$xml->ratingpilot."', division='".$xml->division."' WHERE vid='".$xml->vid."'"); 
$stmt->execute();
if($stmt->rowCount()==0){
     $stmt = $conn->prepare("INSERT INTO users (vid, fname, lname, rating, atc, pilot, division) VALUES (".$xml->vid.",".$xml->firstname.",".$xml->lastname.",".$xml->rating.",".$xml->ratingatc.",".$xml->ratingpilot.",".$xml->division.")"); 
     $stmt->exec($stmt);
     echo 'data inserted into db';
}
  • 写回答

1条回答 默认 最新

  • douchuang1852 2015-07-21 00:04
    关注

    In your second query, you didn't put quotes around the strings. So it treats your variable containing 'aaron' as meaning a column.

    This would be best solved by actually using parameterized queries.

    $query = "INSERT INTO users (vid, fname, ...) VALUES (:vid, :fname, ...)";
    $stmt = $conn->prepare($query);
    $stmt->execute(['vid'=>$xml->vid, 'fname'=>$xml->fname, ...]);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据