feat: dynamically determine URL column in offers table to prevent errors
This commit is contained in:
parent
d46c76d676
commit
c336345845
@ -238,8 +238,23 @@ $productId = isset($_GET['id']) ? (int)$_GET['id'] : 0;
|
||||
</div>
|
||||
|
||||
<?php
|
||||
// Unterschiedliche DB-Stände: URL-Spalte heißt je nach Schema z.B. productURL oder offerURL.
|
||||
// Wir ermitteln die existierende Spalte dynamisch, damit die Seite nicht mit "Unknown column" crasht.
|
||||
$urlColumn = '';
|
||||
$colCheck = mysqli_query($conn, "SHOW COLUMNS FROM offers LIKE 'productURL'");
|
||||
if ($colCheck && mysqli_num_rows($colCheck) > 0) {
|
||||
$urlColumn = 'productURL';
|
||||
} else {
|
||||
$colCheck2 = mysqli_query($conn, "SHOW COLUMNS FROM offers LIKE 'offerURL'");
|
||||
if ($colCheck2 && mysqli_num_rows($colCheck2) > 0) {
|
||||
$urlColumn = 'offerURL';
|
||||
}
|
||||
}
|
||||
|
||||
$urlSelect = $urlColumn !== '' ? ("offers." . $urlColumn . " AS offerURL") : "'' AS offerURL";
|
||||
|
||||
$stmt = mysqli_prepare($conn,
|
||||
"SELECT price, shippingCost, inStock, shops.name, offers.productURL, shops.logoPath, shops.shippingTime
|
||||
"SELECT price, shippingCost, inStock, shops.name, $urlSelect, shops.logoPath, shops.shippingTime
|
||||
FROM offers
|
||||
INNER JOIN shops ON
|
||||
offers.shopID = shops.shopID WHERE offers.productID = ? ORDER BY offers.price ASC");
|
||||
|
||||
Loading…
Reference in New Issue
Block a user