1

我不明白我在此代码中在 MySQL 数据库中创建简单表的错误在哪里:

<?php

// Create connection
$con=mysqli_connect("localhost", "administrator", "199992", "test");

// Check connection
if (mysqli_connect_errno())
{
echo "Failed to connect to MySQL: " . mysqli_connect_error();
}

// Select DB
mysqli_select_db($con, "test");

// Create table
$sql = "CREATE TABLE IF NOT EXISTS Notizen(Benutzer TEXT,Datum TEXT,Notiz TEXT)";  


这应该真的有效,不是吗?
但是当我稍后尝试插入一些东西时:

if(!(empty($_POST[vorname]) and empty($_POST[nachname]) and empty($_POST[notiz]))) {
$sql = "INSERT INTO Notizen (Benutzer, Datum, Notiz)
    VALUES
    ('$_POST[vorname] $_POST[nachname]', 'datum', '$_POST[notiz]')"; 

if (!mysqli_query($con,$sql))
{
echo "Error: " . mysqli_error($con);
 }
}

我收到一个错误:

“错误:表 'test.notize' 不存在”。

4

3 回答 3

5
  1. 正如我在您的代码中看到的,您没有执行创建查询。执行它mysqli_query($con,$sql)
  2. Notizen (Benutzer在创建表查询中在表名和大括号之间留出空格。
  3. 通过使用错误函数创建表来检查您的查询是否正在执行。
于 2013-07-08T13:55:00.170 回答
2

确保使用 mysqli_query() 运行查询。在表定义存储在数据库中之前,您无法插入

于 2013-07-08T13:55:16.137 回答
2

在这条线之后

$sql = "CREATE TABLE IF NOT EXISTS Notizen(Benutzer TEXT,Datum TEXT,Notiz TEXT)";  

您必须运行

if (!mysqli_query($con,$sql))
{
    echo "Error creating a database: " . mysqli_error($con);
}
于 2013-07-08T13:55:44.507 回答