我试图从The Movie Database获取一些数据,使用library在本地使用Xampp在数据库中插入结果。我知道它是脏的(全局函数等),但我在本地运行 - 我只需要它将数据写入数据库如果有任何有效的数据,或重新运行功能如果不是。函数没有写入数据库?
require_once '../vendor/autoload.php';
$token = new \Tmdb\ApiToken('My API Key - removed');
$client = new \Tmdb\Client($token);
$mid = 1;
$conn = new mysqli('localhost', 'root', '', 'test');
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
moviedetails();
function moviedetails() {
global $token;
global $client;
global $mid;
global $conn;
$repository = new \Tmdb\Repository\MovieRepository($client);
$movie = $client->getMoviesApi()->getMovie($mid);
var_dump($movie);
$votecount = $movie['vote_count'];
$voteaverage = $movie['vote_average'];
$image = $movie['poster_path'];
$releasedate = $movie['release_date'];
$id = $movie['id'];
$title = $movie['title'];
$description = $movie['overview'];
$sql = "INSERT INTO movie (votes, vote_average, poster, release_date, dbid, title, description)
VALUES ('$votecount', '$voteaverage', '$image', '$releasedate', '$id', '$title', '$description')";
echo $mid;
$mid++;
moviedetails();
}
我的脚本在$mid
= 3时失败,但未将其他两个有效条目写入我的数据库。
这可能是一个引用问题。保存你的头痛,并切换到[预先准备的语句](http://php.net/manual/en/mysqli.quickstart.prepared-statements.php)和[bind_param](http://php.net/manual/ EN/mysqli的-stmt.bind-param.php)。另外,我没有看到你实际将sql插入数据库的位置。 – aynber
您不是有效地插入到数据库中,而只是准备好执行查询,则不会执行该查询。 – coderodour