0

我看过其他主题,但我无法弄清楚这里有什么问题。例如,如果我用简单的 SELECT * 替换 TRUNCATE 查询,我会得到结果。但这返回错误。我从这个主题复制了以下代码,希望得到结果: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;
}
4

2 回答 2

2

MySQL 用户是否具有截断表所需的权限?来自 MySQL 文档:

[TRUNCATE] 从 MySQL 5.1.16 开始需要 DROP 权限。(在 5.1.16 之前,它需要 DELETE 权限)。

编辑:没有特权会产生某种错误-您是否正在记录或能够看到任何查询错误?

于 2011-06-26T12:26:36.677 回答
0

根据文档,“截断操作不会为删除的行数返回有意义的值。通常的结果是“0行受影响”,应该解释为“没有信息”。见http://dev.mysql.com/doc/refman/5.0/en/truncate-table.html

因此,即使截断成功,您的 if 语句也会沿着 else 路径运行。

于 2011-06-26T12:30:44.880 回答