我看过其他主题,但我不知道这里出了什么问题。例如,如果我用一个简单的SELECT *替换TRUNCATE查询,我确实会得到结果。但这将返回false。我从这个主题复制了以下代码,希望得到一个结果:PHP & MySQL: Truncate multiple tables
我正在通过AMFPHP来做这件事。
# the host used to access DB
define('DB_HOST', 'localhost');
# the username used to access DB
define('DB_USER', 'usr');
# the password for the username
define('DB_PASS', '***');
# the name of your databse
define('DB_NAME', 'name');
//$connection = new __database(DB_HOST,DB_USER,DB_PASS,DB_NAME);
$connection = new mysqli(DB_HOST,DB_USER,DB_PASS,DB_NAME);
if (mysqli_connect_errno())
{
printf("Connect failed: %s\n", mysqli_connect_error());
exit();
}
$query = "TRUNCATE TABLE `books`";
$result = $connection->query($query);
if($result)
{
return $result;
}
else
{
return false;
}发布于 2011-06-26 20:26:37
MySQL用户是否具有截断表所需的权限?从MySQL文档中:
从MySQL 5.1.16开始,
TRUNCATE需要DROP权限。( 5.1.16之前,需要DELETE权限)。
编辑:没有权限将会产生某种类型的错误--您是否正在记录或能够看到任何查询错误?
发布于 2011-06-26 20:30:45
根据文档,“截断操作不会为删除的行数返回有意义的值。通常的结果是”0行受影响“,这应该被解释为”无信息“。请参阅http://dev.mysql.com/doc/refman/5.0/en/truncate-table.html。
因此,即使截断成功,if语句看起来也会沿着else路径运行。
https://stackoverflow.com/questions/6483791
复制相似问题