我有一个.sqlite
数据库:
$db = new PDO("sqlite:db.sqlite");
大小为60MB 。它有1个表。其中一个表列(唯一重的列)包含BLOB_TEXT
个数据。我试图压缩此列值:
$pdo = $db->query("SELECT id, house_plan FROM houses");
$houses = $pdo->fetchAll(PDO::FETCH_ASSOC);
$initial_length = 0;
$compressed_length= 0;
for ($i = 0; $i < count($houses); $i++) {
$id = $houses[$i]["id"];
$house_plan = $houses[$i]["house_plan"];
$compressed = gzcompress($house_plan);
$initial_length += strlen($house_plan);
$compressed_length += strlen($compressed);
flush();
$query = $db->prepare("UPDATE houses SET house_plan=? WHERE id=" . $id);
$query->bindParam(1, $compressed, PDO::PARAM_LOB);
$query->execute();
}
然后打印求和的初始BLOB_TEXT
数据长度和压缩数据长度(替换表中的初始数据):
echo "Before: " . $initial_length . ", After: " . $compressed_length;
// Before: 52222553, After: 2577948
他们在%中的差异:
echo "Difference: " . (100 - round($compressed_length / $initial_length * 100)) . "%";
// Difference: 95%
之后我检查数据库的大小,它仍然是60MB 。 BLOB_TEXT
数据差异为95%,但数据库的大小未更改。
怎么可能?或者压缩BLOB_TEXT
我做错了什么?
我希望数据库大小也会减少,因为这是我唯一的重列。
答案 0 :(得分:5)
在压缩之前,数据库填充到大约100%的数据。 压缩后,它包含大约5%的数据和大约95%的可用空间。
通常,避免减小文件大小是一个好主意,因为无论如何,可用空间将在以后填充新数据。 如果要重新打包数据库,请运行VACUUM。