使用串联在php中执行sql查询


execute sql query in php using concatenation

可能重复:
Mysql可以';t一次执行一个以上的查询

        $query = "TRUNCATE TABLE nw_world;";
        $query = $query . " INSERT INTO `nw_world`";
        $query = $query . " SELECT * FROM `x_world` WHERE x <0 AND y >=0";
        $query = $query . " AND tid !=5 AND aid NOT IN ( 29, 908, 935, 941, 950 )";
        $query = $query . " AND population <=50";
        echo "$query";
        mysql_query($query,$con) or die("error ".mysql_error());

这导致错误

error 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 'INSERT INTO `nw_world` SELECT * FROM `x_world` WHERE x <0 AND y >=0 AND tid !=5 ' at line 1

但是当我在mysql中执行相同的查询时,它工作得很好。因此,我有一种感觉,我在php编码中犯了一些错误。请帮助

PHP默认情况下,每个mysql_query调用只执行一个查询(安全措施)。

如果您想一次执行多个,请查看http://se2.php.net/manual/en/mysqli.multi-query.php

mysql_query不允许执行多个查询。使用mysqli::multi_query或者分别执行每个命令。