如何创建数据库和表,并用数据填充它们?我有错误

我想在它的表中创建一个数据库并用数据填充它。为此,我编写了以下代码,但结果显示错误:


<?php


$json = json_decode(file_get_contents("categories.json"), true)['categories'];

foreach ($json as $elem) {

    print_r($elem);

}


$link = mysqli_connect('localhost', 'root', '');


$sql = "DROP DATABASE cats";

mysqli_query($link, $sql);


$sql = "CREATE DATABASE cats";

mysqli_query($link, $sql);


$sql = "CREATE TABLE cats.categories (id INT NOT NULL AUTO_INCREMENT, id_category INT, name VARCHAR(255), alias VARCHAR(255))";

mysqli_query($link, $sql);

$sql = "CREATE TABLE cats.category_child (id INT NOT NULL AUTO_INCREMENT, id_category INT, id_child INT)";

mysqli_query($link, $sql);


foreach ($json as $elem) {

    $stmt = mysqli_prepare($link, "INSERT INTO cats.categories (id_category, name, alias) VALUES (?, ?, ?)");

    mysqli_stmt_bind_param($stmt, "iss", $elem['id'], $elem['name'], $elem['alias']);

    mysqli_stmt_execute($stmt);

    var_dump(mysqli_error($link));

    mysqli_stmt_close($stmt);


}    


?>

var_dump(mysqli_error($link))打印:string(37) "Table 'cats.categories' doesn't exist" 我做错了什么?


HUX布斯
浏览 126回答 1
1回答

Smart猫小萌

再想一想,这行不通:CREATE TABLE categories (&nbsp; &nbsp; id INT NOT NULL AUTO_INCREMENT,&nbsp; &nbsp; id_category INT,&nbsp; &nbsp; name VARCHAR(255),&nbsp; &nbsp; alias VARCHAR(255));我认为这个错误是不言自明的:表定义不正确;只能有一个自动列,并且必须将其定义为键但是,对于学习 SQL 的人来说,该做什么可能并不完全清楚。您可以将其表述为:CREATE TABLE categories (&nbsp; &nbsp; id INT AUTO_INCREMENT PRIMARY KEY,&nbsp; &nbsp; id_category INT,&nbsp; &nbsp; name VARCHAR(255),&nbsp; &nbsp; alias VARCHAR(255));顺便说一句,使用参数的荣誉!
打开App,查看更多内容
随时随地看视频慕课网APP