Query $wpdb di aggiornamento nel plugin aggiorna solo una colonna
30 gen 2017, 16:25:21
Visualizzazioni: 19K
Voti: 0
Sto eseguendo un aggiornamento dall'area amministrativa di WooCommerce, nella modifica dei dettagli dell'ordine. Ho due problemi:
- Viene aggiornata solo la colonna 'download-count'
- Non riesco a catturare alcun errore SQL
Tuttavia, quando uso la stessa query in un file PHP autonomo, funziona correttamente. Cosa c'è che non va e come posso ottenere gli errori SQL o almeno la query inviata?
$table = $wpdb->prefix . 'woocommerce_downloadable_product_permissions';
$expiry_date = date("Y-m-d", strtotime("+ 30 days"));
$expiry_time = $expiry_date . ' 00:00:10';
$wpdb->query("UPDATE `$table` SET
`downloads_remaining` = '1',
`access_expires` = '$expiry_time',
`download_count` = (`download_count` + 1)
WHERE `order_id` = '$post_id'");
Ecco la versione "standalone" in PHP che funziona:
$link = mysqli_connect($servername, $username, $password, $db);
$post_id = '219';
if (!$link) { exit; }
$expiry_date = date("Y-m-d", strtotime("+ 30 days"));
$expiry_time = $expiry_date . ' 00:00:00';
$table = 'hkmw_woocommerce_downloadable_product_permissions';
$query = "UPDATE `$table` SET
`downloads_remaining` = '1',
`access_expires` = '$expiry_time',
`download_count` = (`download_count` + 1)
WHERE `order_id` = '$post_id';";
if (!mysqli_query($link,$query)) {
printf("Errormessage: %s\n", mysqli_error($link));
}
mysqli_close($link);
Commenti
Tutte le risposte alla domanda
1
0
Ho dovuto utilizzare due query separate. La sintassi $wpdb->update non può gestire calcoli basati sul valore esistente. Ma per gli altri due campi funziona. Ecco come ho fatto:
$table = $wpdb->prefix . 'woocommerce_downloadable_product_permissions';
$expiry_date = date("Y-m-d", strtotime("+ 30 days")); // Data di scadenza tra 30 giorni
$expiry_time = $expiry_date . ' 00:00:00'; // Aggiungiamo l'orario di scadenza
$wpdb->query("UPDATE $table SET
download_count = (download_count + 1) // Incrementa il contatore dei download
WHERE order_id = '$post_id'");
$wpdb->update( $table,
array(
'downloads_remaining' => '1', // Imposta i download rimanenti a 1
'access_expires' => $expiry_time // Imposta la data di scadenza
),
array( 'order_id' => $post_id ), // Condizione WHERE
array( '%s', '%s' ), // Formato dei valori
array( '%d' ) // Formato della condizione
);

hal
35
21 feb 2017 14:42:57
Domande correlate