我想在其表内创建一个数据库,并用数据填充它。 为此,我编写了以下代码,但结果是一个错误:
<?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"
我在做什么错了?
答案 0 :(得分:3)
再三考虑,这是行不通的:
CREATE TABLE categories (
id INT NOT NULL AUTO_INCREMENT,
id_category INT,
name VARCHAR(255),
alias VARCHAR(255)
);
我认为该错误是不言自明的:
错误的表定义;只能有一个自动列,并且必须将其定义为键
但是,对于学习SQL的人来说,可能还不清楚。您可以将其表达为:
CREATE TABLE categories (
id INT AUTO_INCREMENT PRIMARY KEY,
id_category INT,
name VARCHAR(255),
alias VARCHAR(255)
);
顺便说一句,使用参数的荣誉!