教程 > MySQL 教程 > MySQL 教程 阅读:37

MySQL 创建表

创建MySQL数据表需要以下信息:

  • 表名
  • 表字段名
  • 定义每个表字段

语法

以下为创建MySQL数据表的SQL通用语法:

CREATE TABLE table_name (column_name column_type);

以下例子中我们将在 JIYIK 数据库中创建数据表jiyik_tbl:

CREATE TABLE IF NOT EXISTS `jiyik_tbl`(
   `jiyik_id` INT UNSIGNED AUTO_INCREMENT,
   `jiyik_title` VARCHAR(100) NOT NULL,
   `jiyik_author` VARCHAR(40) NOT NULL,
   `submission_date` DATE,
   PRIMARY KEY ( `jiyik_id` )
)ENGINE=InnoDB DEFAULT CHARSET=utf8;

实例解析:

  • 如果你不想字段为 NULL 可以设置字段的属性为 NOT NULL, 在操作数据库时如果输入该字段的数据为NULL ,就会报错。
  • AUTO_INCREMENT定义列为自增的属性,一般用于主键,数值会自动加1。
  • PRIMARY KEY关键字用于定义列为主键。 您可以使用多列来定义主键,列间以逗号分隔。
  • ENGINE 设置存储引擎,CHARSET 设置编码。

通过命令提示符创建表

通过 mysql> 命令窗口可以很简单的创建MySQL数据表。你可以使用 SQL 语句 CREATE TABLE 来创建数据表。

示例

以下为创建数据表 jiyik_tbl 实例:

[root@host]$ mysql -u root -p
Enter password:*******

进入mysql管理应用程序

mysql> use JIYIK;
Database changed
mysql> CREATE TABLE jiyik_tbl(
   -> jiyik_id INT NOT NULL AUTO_INCREMENT,
   -> jiyik_title VARCHAR(100) NOT NULL,
   -> jiyik_author VARCHAR(40) NOT NULL,
   -> submission_date DATE,
   -> PRIMARY KEY ( jiyik_id )
   -> )ENGINE=InnoDB DEFAULT CHARSET=utf8;
Query OK, 0 rows affected (0.16 sec)
mysql>

注意:MySQL命令终止符为分号 ; 。

注意: -> 是换行符标识,不要复制。


使用PHP脚本创建数据表

你可以使用 PHP 的mysqli query()或mysql_query()函数来创建已存在数据库的数据表。

该函数有两个参数,在执行成功时返回 TRUE,否则返回 FALSE。

语法

$mysqli->query($sql,$resultmode)
参数 描述
$sql 必需。规定要使用的 MySQL 连接。
resultmode 可选。一个常量。可以是下列值中的任意一个:
MYSQLI_USE_RESULT(如果需要检索大量数据,请使用这个)
MYSQLI_STORE_RESULT(默认)

示例

以下示例使用了PHP脚本来创建数据表:

<?php
     $dbhost = 'localhost';
     $dbuser = 'root';
     $dbpass = 'root@123';
     $dbname = 'JIYIK';
     $mysqli = new mysqli($dbhost, $dbuser, $dbpass, $dbname);

     if($mysqli->connect_errno ) {
            printf("Connect failed: %s<br />", $mysqli->connect_error);
            exit();
     }
     printf('Connected successfully.<br />');

     $sql = "CREATE TABLE jiyik_tbl( ".
            "jiyik_id INT NOT NULL AUTO_INCREMENT, ".
            "jiyik_title VARCHAR(100) NOT NULL, ".
            "jiyik_author VARCHAR(40) NOT NULL, ".
            "submission_date DATE, ".
            "PRIMARY KEY ( jiyik_id )); ";
     if ($mysqli->query($sql)) {
            printf("Table tutorials_tbl created successfully.<br />");
     }
     if ($mysqli->errno) {
            printf("Could not create table: %s<br />", $mysqli->error);
     }

     $mysqli->close();
?>

执行成功后,就可以通过命令行查看表结构:

Mysql 创建表查询结构

查看笔记

扫码一下
查看教程更方便