为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

PHP
HUX布斯 2021-07-05 13:10:09
我想在它的表中创建一个数据库并用数据填充它。为此,我编写了以下代码,但结果显示错误:<?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" 我做错了什么?
查看完整描述

1 回答

?
Smart猫小萌

TA贡献1911条经验 获得超7个赞

再想一想,这行不通:


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)

);

顺便说一句,使用参数的荣誉!


查看完整回答
反对 回复 2021-07-09
  • 1 回答
  • 0 关注
  • 125 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信