表存在时,如果表示不存在则表示创建表失败

时间:2013-05-15 00:08:02

标签: php mysql mysqli mysql-error-1050

我有以下代码:

$db_host = 'localhost';
$db_port = '3306';
$db_username = 'root';
$db_password = 'root';
$db_primaryDatabase = 'dsl_ams';

// Connect to the database, using the predefined database variables in /assets/repository/mysql.php
$dbConnection = new mysqli($db_host, $db_username, $db_password, $db_primaryDatabase);

// If there are errors (if the no# of errors is > 1), print out the error and cancel loading the page via exit();
if (mysqli_connect_errno()) {
    printf("Could not connect to MySQL databse: %s\n", mysqli_connect_error());
    exit();
}

$queryCreateUsersTable = "CREATE TABLE IF NOT EXISTS `USERS` (
    `ID` int(11) unsigned NOT NULL auto_increment,
    `EMAIL` varchar(255) NOT NULL default '',
    `PASSWORD` varchar(255) NOT NULL default '',
    `PERMISSION_LEVEL` tinyint(1) unsigned NOT NULL default '1',
    `APPLICATION_COMPLETED` boolean NOT NULL default '0',
    `APPLICATION_IN_PROGRESS` boolean NOT NULL default '0',
    PRIMARY KEY  (`ID`)
)";

if(!$dbConnection->query($queryCreateUsersTable)){
    echo "Table creation failed: (" . $dbConnection->errno . ") " . $dbConnection->error;
}

哪些输出......

Table creation failed: (1050) Table '`dsl_ams`.`USERS`' already exists

我不明白的是:如果该表已经存在,那么IF NOT EXISTS是否应该取消SQL查询的执行?换句话说,如果表存在,它不应该退出if语句而不回显任何东西,而不是尝试执行查询吗?

在没有向用户输出任何内容的情况下,尝试找到“创建不存在的表格”的最佳方法。

2 个答案:

答案 0 :(得分:1)

您应该收到警告,而不是错误。你正在运行什么版本? 无论如何,如果你想在SQL查询之前显示错误类型: SET sql_notes = 0; 然后键入SET sql notes = 1;在查询之后。

答案 1 :(得分:0)

I use your script in mysql is true:
mysql> select version();
+-----------+
| version() |
+-----------+
| 5.5.30    |
+-----------+
1 row in set (0.01 sec)

$queryCreateUsersTable = "CREATE TABLE IF NOT EXISTS `sun_channel` (
    `ID` int(11) unsigned NOT NULL auto_increment,
    `EMAIL` varchar(255) NOT NULL default '',
    `PASSWORD` varchar(255) NOT NULL default '',
    `PERMISSION_LEVEL` tinyint(1) unsigned NOT NULL default '1',
    `APPLICATION_COMPLETED` boolean NOT NULL default '0',
    `APPLICATION_IN_PROGRESS` boolean NOT NULL default '0',
    PRIMARY KEY  (`ID`)
)";
$res = mysql_query($queryCreateUsersTable);
var_dump($res);
die;

//show bool(true)