Cài đặt V4 sạch lỗi

Installer này tự tạo bảng, tự thêm cột slug nếu DB cũ đang thiếu, và có thể chạy lại để cập nhật cấu trúc cơ bản.


$videoCheck = $pdo->query("SELECT COUNT(*) FROM videos")->fetchColumn(); if ((int)$videoCheck === 0) { $stmt = $pdo->prepare("INSERT INTO videos (title, youtube_url, thumbnail, sort_order, is_active) VALUES (?,?,?,?,?)"); $stmt->execute(['Thánh ca Mùa Chay - 40 bài nghe sám hối', 'https://www.youtube.com', 'assets/images/placeholder.svg', 1, 1]); $stmt->execute(['Thánh lễ cuối tuần 2026', 'https://www.youtube.com', 'assets/images/placeholder.svg', 2, 1]); $stmt->execute(['Nhạc thánh ca Mừng Xuân 2026', 'https://www.youtube.com', 'assets/images/placeholder.svg', 3, 1]); $stmt->execute(['Sao Em Không Lần Chuỗi - Tâm Ca', 'https://www.youtube.com', 'assets/images/placeholder.svg', 4, 1]); $stmt->execute(['Thánh Ca Tháng Hoa Dâng Mẹ Maria', 'https://www.youtube.com', 'assets/images/placeholder.svg', 5, 1]); } try { $albumCheck = $pdo->query("SELECT COUNT(*) FROM albums")->fetchColumn(); if ((int)$albumCheck === 0) { $stmt = $pdo->prepare("INSERT INTO albums (title, image, sort_order, is_active) VALUES (?,?,?,?)"); $stmt->execute(array('Mẹ là mùa hoa dịu êm', 'assets/images/placeholder.svg', 1, 1)); $stmt->execute(array('Mẹ là mùa xuân tin Công giáo', 'assets/images/placeholder.svg', 2, 1)); $stmt->execute(array('Những nhà thờ cổ mùa sắc đẹp', 'assets/images/placeholder.svg', 3, 1)); $stmt->execute(array('Chiêm ngưỡng nhà thờ đẹp nhất', 'assets/images/placeholder.svg', 4, 1)); } } catch (Exception $e) {}