bind_param () scheint nicht zu funktionieren

Ich habe folgenden Code:

<?php
$dbhost = 'localhost';
$dbuser = 'user';
$dbpass = 'password';
$db = new mysqli($dbhost, $dbuser, $dbpass, 'images_db');
if($db->connect_errno > 0){
die('Unable to connect to database [' . $db->connect_error . ']');
}
else{
echo "Connected to database";
}
//filename, mime_type and file_size are columns in the table images
$stmt = $db->prepare("INSERT INTO images (filename, mime_type, file_size) VALUES (?, ?, ?)");
$string1 = 'string 1';
$string2 = 'string 2';
$stmt->bind_param('ssi', $string1, $string2, 123);
$stmt->execute();
$stmt->close();
$mysqli->close();
?>

Wenn ich den Code ausführe, wird nichts zur mysql-Datenbank hinzugefügt. Aber wenn ich die Zeile auskommentiere

$stmt->bind_param('ssi', $string1, $string2, 123);

und fügen Sie die Zeichenfolgen- und Ganzzahlwerte direkt in die Anweisung $ db-> prepare ein (ersetzen Sie die Fragezeichen), alles funktioniert einwandfrei und die Zeile wird der Datenbanktabelle hinzugefügt.

Was mache ich falsch in der Zeile bind_param, die verhindert, dass die neue Zeile zur Datenbank hinzugefügt wird?