首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >foreach循环中mysql的误操作

foreach循环中mysql的误操作
EN

Stack Overflow用户
提问于 2014-02-18 09:43:19
回答 2查看 42关注 0票数 2

我运行这个页面,就会出现这个错误。我仍然找不出问题在哪里:

错误:您的SQL语法出现了错误;请检查与您的MySQL服务器版本对应的手册,以便在第2行使用接近“right,createtime”值('test10',1,1,now())的正确语法。

代码语言:javascript
复制
foreach($array as $value){

    //insert record
$sql2 = "INSERT INTO projectright
        (generalusername,projectid,right,createtime)
        VALUES
        ('$_POST[username]',
        ".$value.",
        1,
        now())";    

        if (!mysql_query($sql2,$con))

  {

  die('Error: ' . mysql_error());

  }
}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-02-18 09:46:15

right是保留关键字

你应该像这样从后面逃出来。

代码语言:javascript
复制
   INSERT INTO projectright
    (generalusername,projectid,`right`,createtime)
    .....
    .....

在创建/按列播放时,请查看保留关键词,然后用backticks将其转义。

试试这个:

代码语言:javascript
复制
  foreach($array as $value){


 $sql2 = "INSERT INTO projectright
    (generalusername,projectid,`right`,createtime)
    VALUES
    (".$_POST['username'].",
    ".$value.",
    1,
    now())";    

    if (!mysql_query($sql2,$con))

  {

  die('Error: ' . mysql_error());

  }
 }
  • 正如草莓说的:最好不要保留关键字。
票数 4
EN

Stack Overflow用户

发布于 2014-02-18 09:48:23

$value是一个数组,这很可能是错误的原因。试一试如下:

代码语言:javascript
复制
$sql2 = "INSERT INTO projectright
        (generalusername,projectid,right,createtime)
        VALUES
        ('$_POST[username]',
        ".implode($value).",
        1,
        now())";    
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21849700

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档