这是一个场景,我正在上传一个sql查询的txt文件。每次成功上传,我都需要执行其内容。
好吧,我似乎无法执行一组查询。只需单行查询。
我有query.txt:
USE `wifi_analyzer`;
CREATE TABLE 'test' (
'username' varchar(10) NOT NULL,
'password' varchar(10) NOT NULL
);
这就是我在cakephp文件中执行它的方式。
$fullFile = $file_path.$file_name;
$readFile = fopen($file_path.$file_name, 'r');
$contents = fread($readFile,filesize($fullFile));
$this->User->query($contents);
可以读取文件及其内容。但是,它显示错误:
SQL Error: 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 'CREATE TABLE 'test' (
'username' varchar(10) NOT NULL,
'password' varchar(10' at line 3 [CORE\cake\libs\model\datasources\dbo_source.php, line 673]
好吧,如果只是这样的单行查询:
Select * from sometable;
它不会显示任何错误。但是这个单一的查询:
CREATE TABLE 'test' (
'username' varchar(10) NOT NULL,
'password' varchar(10) NOT NULL
);
它也没有执行。
更新: 好吧,我读过这个: http://www.hardcode.nl/subcategory_4/article_558-execute-mysql-sql-dump-files-via-php-mysqli.htm
但不知道如果这会有所帮助,因为我在cakephp中这样做
答案 0 :(得分:3)
不要对表名和字段名使用单引号。执行以下查询它将起作用
CREATE TABLE `test` (
`username` varchar( 10 ) NOT NULL ,
`password` varchar( 10 ) NOT NULL
);