2013-03-24 84 views
0

不行我有一个查询,在phpmyadmin的工作,但不能在PHP的工作(mysqliMySQL查询工作,但在库MySQLi

问题出在哪里?

查询:

INSERT INTO `SepidarSoft_Portal`.`Archive_Media` SET `CTime`='1364135670',`UTime`='1364135670',`PID`='',`State`='1',`Sequence`='0',`Subject`='Hojom Marg (www.Parstafrih.ir)',`Text`='',`Description`='',`Definition`='',`KeyWord`='',`ETag`='',`Access`='',`LinkToPage`='',`Attachment`='[{\"Name\":null,\"Kind\":null,\"Size\":false,\"Address\":\"27\",\"More\":{\"Original\":1}}]',`STime`='0',`ETime`='0'; 

    SET @LAST_ID:=LAST_INSERT_ID(); 

    INSERT INTO `SepidarSoft_Portal`.`Archive_Media_MoreInfo` (`id`,`Key`,`Value`) VALUES (@LAST_ID,'Instrumental','1'),(@LAST_ID,'KindFile','صوتی'),(@LAST_ID,'Genre','نغمه'),(@LAST_ID,'SName','Amir Tajik (www.Parstafrih.ir)'),(@LAST_ID,'Events','[[\"\"]]'),(@LAST_ID,'Album','(www.Parstafrih.ir)'),(@LAST_ID,'Composer',''),(@LAST_ID,'Adjustment',''),(@LAST_ID,'Subtitle','[object HTMLInputElement]'),(@LAST_ID,'Release',''); 

错误:

#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 'SET @LAST_ID:=LAST_INSERT_ID(); 

1)我使用PHP mysqli_multi_query这个

+0

你插入MySQL的一个可能的'''? – samayo 2013-03-24 14:46:14

+0

@phpNoOb不,这是通过'\'插入查询的输出' – 2013-03-24 14:49:38

+1

我不明白为什么有人低估了这个问题! – 2013-03-24 14:54:50

回答

0

你的问题很简单。

反引号(`)用于在php中执行命令。这就是为什么你会被给出语法错误。用你的mysqli函数中的单引号或双引号替换它们。

请阅读下面的文档,你应该进行排序:)

Backticks on php.net

+0

我改变(')但mysql给我这个改变的错误。 – 2013-03-24 15:04:50

+0

从你的链接'注意:与其他语言不同,反引号不能用在双引号字符串中。'因此''mysqli_multi_query(“INSERT INTO \'SepidarSoft_Portal \'。\'Archive_Media \'SET ...”)''不会执行一个命令。当表和/或列名是MySQL保留字时,使用反引号是可以接受的。另请参见http://stackoverflow.com/a/11321508/689579 – Sean 2013-03-24 15:11:34

+0

此外,如果您的MySQL不处于[ANSI模式](http:/ usr/share//dev.mysql.com/doc/refman/5.0/en/server-sql-mode.html)使用[ANSI_QUOTES](http://dev.mysql.com/doc/refman/5.0/en/server-sql- mode.html#sqlmode_ansi_quotes),[默认情况下,MySQL没有启用特殊模式](http://dev.mysql.com/doc/refman/5.0/en/faqs-sql-modes.html#qandaitem-B-3 -1-7)。 – Sean 2013-03-24 15:20:07