3

我正在尝试将数据插入 Mysql 表,但它给了我一个错误,因为-

您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 1 行的 'Scoretab VALUES ('UX 345','22','0.8562675')' 附近使用正确的语法

这是我使用的 php-mysql 片段:

if($value >= 0.70){         
  $mu_id = $ros['c_id'];
  $moc_id = $ram['t_id'];
  $query="INSERT INTO Scoretab VALUES ('$mu_id','$moc_id','$value')";

  $op1 = mysql_query($query) or die(mysql_error());         
}

这是我的表结构:

CREATE TABLE IF NOT EXISTS `Scoretab` (
 `mu_id` varchar(10) NOT NULL,
 `moc_id` int(5) NOT NULL,
 `score` decimal(5,4) NOT NULL,
 UNIQUE KEY `mu_id` (`mu_id`)
)
4

3 回答 3

2

此查询可能存在一些问题

$query="INSERT INTO Scoretab VALUES ('$mu_id','$moc_id','$value')";
  • 列数是否与您尝试插入的字段匹配?您是否尝试过使用特定的列标识符Scoretab (col,col,col) values (val, val, val)

  • 您的任何值是否包含未转义的撇号?您可能需要考虑使用mysql_real_escape_string$mu_idintval $moc_id

  • $value是一个浮点数,您在插入时不需要添加撇号

  • 你确定你连接到你有这个表的同一个数据库吗?

这可能是一个可行的解决方案(编辑

if ($value >= 0.70)
{
    $mu_id = mysql_real_escape_string($ros['c_id']);

    $moc_id = intval($ram['t_id']); 

    $query = "INSERT INTO `Scoretab` VALUES ('$mu_id', $moc_id, $value)";

    $op1 = mysql_query($query) or die(mysql_error());
}
于 2013-05-01T03:26:31.253 回答
1

试试这个

 $query="INSERT INTO Scoretab  (mu_id,moc_id,score) VALUES ('$mu_id','$moc_id','$value')";
于 2013-05-01T03:37:03.213 回答
1

该错误似乎在表名之前Scoretab。你仔细检查你的语法了吗?有时我们看不到眼前的一切!:D 只是复制了这个例子,一切都对我有用。

于 2013-05-01T03:45:37.553 回答