插入查询在我的 php 文件中不起作用

Insert query is not working in my php file

我正在从一个 csv 文件中获取值并将它们插入我的 sql tables.
我正在尝试插入(或替换)。它不工作。但是当我使用更新查询时,它工作正常并正确更新值。
我不确定我的脚本有什么问题。

$query_insert = "
INSERT INTO
    `ps_product`
    (
         `id_product`
        ,`id_supplier`
        ,`id_manufacturer`
        ,`id_category_default`
        ,`id_shop_default`
        ,`id_tax_rules_group`
        ,`on_sale`
        ,`online_only`
        ,`ean13`
        ,`upc`
        ,`ecotax`
        ,`quantity`
        ,`minimal_quantity`
        ,`price`
        ,`wholesale_price`
        ,`unity`
        ,`unit_price_ratio`
        ,`additional_shipping_cost`
        ,`reference`
        ,`supplier_reference`
        ,`location`
        ,`width`
        ,`height`
        ,`depth`
        ,`weight`
        ,`out_of_stock`
        ,`quantity_discount`
        ,`customizable`
        ,`uploadable_files`
        ,`text_fields`
        ,`active`
        ,`redirect_type`
        ,`id_product_redirected`
        ,`available_for_order`
        ,`available_date`
        ,`condition`
        ,`show_price`
        ,`indexed`
        ,`visibility`
        ,`cache_is_pack`
        ,`cache_has_attachments`
        ,`is_virtual`
        ,`cache_default_attribute`
        ,`date_add`
        ,`date_upd`
        ,`advanced_stock_management`
    )
    VALUES
    (
         " .$ID ."
        ,'2'
        ,'" .$id_manu ."'
        ,'" .$categoryRec ."'
        ,'2'
        ,'2'
        ,'0'
        ,'0'
        ,'" .$EAN ."'
        ,'" .$UPC ."'
        ,'0.000000'
        ,'0'
        ,'1'
        ,'" .$retailp ."'
        ,'" .$wholesalep ."'
        ,''
        ,'0.000000'
        ,'0.00'
        ,'" .$ref ."'
        ,'" .$ID ."'
        ,''
        ,'0.000000'
        ,'0.000000'
        ,'0.000000'
        ,'0.000000'
        ,'2'
        ,'0'
        ,'0'
        ,'0'
        ,'0'
        ,'1'
        ,''
        ,'0'
        ,'1'
        ,'0000-00-00'
        ,'new'
        ,'1'
        ,'1'
        ,'both'
        ,'0'
        ,'0'
        ,'0'
        ,'0'
        ,'" .$dateadded ."'
        ,'" .$dateupdated ."'
        ,'0'
    )
";

//  echo $query_insert;

mysql_query( $query_insert ,$conn );

但使用相同的值我的更新查询工作完美。谁能看到我在这里做错了什么?

mysql_query("UPDATE `ps_product` SET `id_supplier`=1,`id_manufacturer`=$id_manu,`id_category_default`=$categoryRec,`id_shop_default`=1,`id_tax_rules_group`=1,`on_sale`=0,`online_only`=0,`ean13`='$EAN',`upc`='$UPC',`ecotax`=0.000000,`quantity`=0,`minimal_quantity`=1,`price`='$retailp',`wholesale_price`='$wholesalep',`unity`='',`unit_price_ratio`=0.000000,`additional_shipping_cost`=0.00,`reference`='$ref',`supplier_reference`=$ID,`location`='',`width`=0.000000,`height`=0.000000,`depth`=0.000000,`weight`=0.000000,`out_of_stock`=2,`quantity_discount`=0,`customizable`=0,`uploadable_files`=0,`text_fields`=0,`active`=1,`redirect_type`='',`id_product_redirected`=0,`available_for_order`=1,`available_date`='0000-00-00',`condition`='new',`show_price`=1,`indexed`=1,`visibility`='both',`cache_is_pack`=0,`cache_has_attachments`=0,`is_virtual`=0,`cache_default_attribute`=0,`date_add`='$dateadded',`date_upd`='$dateupdated',`advanced_stock_management`=0  WHERE `id_product`=$ID",$conn);  

我必须指出,我输入的产品不在 table 中,而我要更新的产品在系统中。所以我已经测试过了。

Online_only 未正确引用

对于 id_supplier 的主键,您提供一个值作为 $ID,而不是给出一个空值,如下所示

mysql_query("INSERT INTO `ps_product` (`id_product`,`id_supplier`,`id_manufacturer`,`id_category_default`,`id_shop_default`,`id_tax_rules_group`,`on_sale,online_only`,`ean13`,`upc`,`ecotax`,`quantity`,`minimal_quantity`,`price`,`wholesale_price`,`unity`,`unit_price_ratio`,`additional_shipping_cost`,`reference`,`supplier_reference`,`location`,`width`,`height`,`depth`,`weight`,`out_of_stock`,`quantity_discount`,`customizable`,`uploadable_files`,`text_fields`,`active`,`redirect_type`,`id_product_redirected`,`available_for_order`,`available_date`,`condition`,`show_price`,`indexed`,`visibility`,`cache_is_pack`,`cache_has_attachments`,`is_virtual`,`cache_default_attribute`,`date_add`,`date_upd`,`advanced_stock_management`) VALUES ('',2,$id_manu,$categoryRec,2,2,0,0,'$EAN','$UPC',0.000000,0,1,'$retailp','$wholesalep','',0.000000,0.00,'$ref',$ID,'',0.000000,0.000000,0.000000,0.000000,2,0,0,0,0,1,'',0,1,'0000-00-00','new',1,1,'both',0,0,0,0,'$dateadded','$dateupdated',0)",$conn);

因为主键是自增的所以会自动自增