简体   繁体   English

用php创建表

[英]Creation table with php

i have a problem with the 'create table' in PHP.我在 PHP 中的“创建表”有问题。 The name of table is the name of the user registered.表名是注册的用户名。 The problem is in '$nuovidati'.问题在于'$nuovidati'。 The registration script work but doesn't create table.....注册脚本工作但不创建表.....

Code:代码:

    <?php
    require('config.php');
    if(isset($_POST['registra']))
    {
        $user = (isset($_POST['user'])) ? trim($_POST['user']) : '';
        $pass = (isset($_POST['pass'])) ? trim($_POST['pass']) : '';
        $mail = (isset($_POST['mail'])) ? trim($_POST['mail']) : '';
        if (!get_magic_quotes_gpc()) {
            $user = addslashes($user);
            $pass = addslashes($pass);
            $mail = addslashes($mail);
        }
        if(strlen($user) < 4 || strlen($user) > 12)
            die('Nome Utente troppo corto, o troppo lungo');
        elseif(strlen($pass) < 4 || strlen($pass) > 12)
            die('Password troppo corta, o troppo lunga');
        elseif(!eregi("^[a-z0-9][_\.a-z0-9-]+@([a-z0-9][0-9a-z-]+\.)+([a-z]{2,4})", $mail))
            die('Email non valida');
        elseif(mysql_num_rows(mysql_query("SELECT user FROM utenti WHERE user = '$user' LIMIT 1")) == 1)
            die('Nome Utente non disponibile');
        elseif(mysql_num_rows(mysql_query("SELECT mail FROM utenti WHERE mail = '$mail' LIMIT 1")) == 1)
            die('Questo indirizzo email risulta gi&agrave; registrato ad un altro utente');
        else
        {
            $pass = md5($pass);
            $strSQL = "INSERT INTO utenti (user,pass,mail)";
            $strSQL .= "VALUES('$user', '$pass', '$mail')";
            mysql_query($strSQL) OR die("Errore 003, contattare l'amministratore ".mysql_error());
            $index = 'modello.php';
            copy($index, $user) or die("Errore copia.");
            $rin = basename($user, ".php").".php";
            rename($user, $rin);
    $nuovidati = "CREATE TABLE ".$user."
    (
           descrizione varchar(100) DEFAULT NULL,
           data date NOT NULL,
           entrata varchar(10000) NOT NULL,
           uscita varchar(10000) DEFAULT NULL,
           saldo varchar(100) DEFAULT NULL,
           id mediumint(9) NOT NULL AUTO_INCREMENT
    )";
mysql_query($nuovidati) OR die("Erroe: ".mysql_error());
            header('Location: registrato.php');
            exit;
        }
    }
    ?>

Here is the working code:这是工作代码:

$nuovidati = "CREATE TABLE $user 
(
        descrizione varchar(100) DEFAULT NULL,
        data date NOT NULL,
        entrata varchar(10000) NOT NULL,
        uscita varchar(10000) DEFAULT NULL,
        saldo varchar(100) DEFAULT NULL,
        id mediumint(9) NOT NULL AUTO_INCREMENT,
        primary key (id)
)"; 
mysql_query($nuovidati) OR die("Errore: ".mysql_error());

Seems to me like a SQL error, try this:在我看来像一个 SQL 错误,试试这个:

"CREATE TABLE $user
(
   id mediumint(9) NOT NULL AUTO_INCREMENT,
   descrizione varchar(100) NULL DEFAULT NULL,
   data date NOT NULL,
   entrata varchar(10000) NOT NULL,
   uscita varchar(10000) NULL DEFAULT NULL,
   saldo varchar(100) NULL DEFAULT NULL,
   PRIMARY KEY (id)
)";

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM