donglian1953 2019-02-10 04:23
浏览 71
已采纳

Mysqli错误 - 错误:您的SQL语法有错误[关闭]

For the life of me I can't see why I'm getting this error:

ERROR: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '(components_ID, CompStep, MaterialQty, materials_ID) ' at line 2

SQL code variable:

$insertmat = "INSERT INTO components_has_materials 
              SET (components_ID, CompStep, MaterialQty, materials_ID) 
              VALUES ('$compId[0]', '$recStep', '$matQty', '$matCode')";

If statement from PHP code that is attempting to insert into the db:

                   if(mysqli_query($db, $insertmat)){
                        mysqli_close($db);
                        $addMatError = "Component material added";
                    }else{
                        echo 'ERROR: '. mysqli_error($db);
                    }

What's wrong with this bit of code?

  • 写回答

1条回答 默认 最新

  • doukuilian8365 2019-02-10 04:26
    关注

    Remove the SET. You don’t use SET when providing a columns list and a VALUES list. This is explained in the MySQL documentation for INSERT.

    As shown in the docs, these are two (alternative) syntax options for an INSERT query:

    INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
        [INTO] tbl_name
        [PARTITION (partition_name [, partition_name] ...)]
        [(col_name [, col_name] ...)]
        {VALUES | VALUE} (value_list) [, (value_list)] ...
        [ON DUPLICATE KEY UPDATE assignment_list]
    
    INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
        [INTO] tbl_name
        [PARTITION (partition_name [, partition_name] ...)]
        SET assignment_list
        [ON DUPLICATE KEY UPDATE assignment_list]
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部