dtysql0586 2013-11-24 09:16
浏览 68
已采纳

Symfony2抛出学说异常“检查与您的MySQL服务器版本对应的手册,以便在'group'附近使用正确的语法”

I'm working on a symfony project, I tried to add a data to database using entity but I got an Doctrine sql error?!!!! so any help is appritiated in advanced

I made an entity myselft which is :

/**
 * @ORM\Table(name="u001_user_group")
 * @ORM\Entity
 */
 class UserGroup 
 {       
    /**
     * @var integer
     *
     * @ORM\Column(name="group", type="integer", length=20, nullable=false)
     */
    private $group;

    public function setGroup($group)
    {
        $this->group = $group;

        return $this;
    }

    public function getGroup()
    {
        return $this->group;
    }
}       

And when I try to add something like this:

$UserGroup= new UserGroup();
            $UserGroup->setUser($registerAction->getId());
            $UserGroup->setGroup(4);
            $em->persist($UserGroup);
            $em->flush();

it give me this error:

An exception occurred while executing 'INSERT INTO u001_user_group (user, group) VALUES (?, ?)' with params [20, 4]:

SQLSTATE[42000]: Syntax error or access violation: 1064 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 'group) VALUES (20, 4)' at line 1

  • 写回答

2条回答 默认 最新

  • doushi1974 2013-11-24 10:52
    关注

    What @nifr said.

    Just to add, if you absolutely need to use group you can use backticks to escape it like so:

    /**
     * @var integer
     *
     * @ORM\Column(name="`group`", type="integer", length=20, nullable=false)
     */
    private $group;
    

    But generally speaking it's good practice to avoid reserved words.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么