表名 表字段名 定义每个表字段
MySQL 允许我们通过两种方式在数据库中创建表:
MySQL命令行客户端
MySQL 工作台
语法
CREATE TABLE [IF NOT EXISTS] table_name( column_definition1, column_definition2, …….., table_constraints ); 也可简写为: CREATE TABLE table_name (column_name column_type);
范围 | 描述 |
---|---|
table_name | 它是一个新表的名称。它在 MySQL 数据库中应该是唯一的。这个IF NOT EXISTS表示,如果我们当前数据库中已经存在一个同名的表将不会执行改语句,避免了系统报错。 |
column_definition | 它定义列的名称以及每列的数据类型。表定义中的列由逗号运算符分隔。列定义的语法如下: column_name1 data_type(size) [NULL | 非空] |
table_constraints | 它指定了表约束,如 PRIMARY KEY、UNIQUE KEY、FOREIGN KEY、CHECK 等。 |
CREATE TABLE IF NOT EXISTS `runoon_tbl`(
`runoon_id` INT UNSIGNED AUTO_INCREMENT,
`runoon_title` VARCHAR(100) NOT NULL,
`runoon_author` VARCHAR(40) NOT NULL,
`submission_date` DATE,
PRIMARY KEY ( `runoon_id` )
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
如果你不想字段为 NULL 可以设置字段的属性为 NOT NULL, 在操作数据库时如果输入该字段的数据为NULL ,就会报错。 AUTO_INCREMENT定义列为自增的属性,一般用于主键,数值会自动加1。 PRIMARY KEY关键字用于定义列为主键。您可以使用多列来定义主键,列间以逗号分隔。 ENGINE 设置存储引擎,CHARSET 设置编码。
通过命令提示符创建表
root@host# mysql -u root -p
Enter password:*******
mysql> use RUNOON;
Database changed
mysql> CREATE TABLE runoon_tbl(
-> runoon_id INT NOT NULL AUTO_INCREMENT,
-> runoon_title VARCHAR(100) NOT NULL,
-> runoon_author VARCHAR(40) NOT NULL,
-> submission_date DATE,
-> PRIMARY KEY ( runoon_id )
-> )ENGINE=InnoDB DEFAULT CHARSET=utf8;
Query OK, 0 rows affected (0.16 sec)
mysql>
使用PHP脚本创建数据表
语法
mysqli_query(connection,query,resultmode);
创建数据表
以下实例使用了PHP脚本来创建数据表:
<?php
$dbhost = 'localhost'; // mysql服务器主机地址
$dbuser = 'root'; // mysql用户名
$dbpass = '123456'; // mysql用户名密码
$conn = mysqli_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
die('连接失败: ' . mysqli_error($conn));
}
echo '连接成功<br >';
$sql = "CREATE TABLE runoon_tbl( ".
"runoon_id INT NOT NULL AUTO_INCREMENT, ".
"runoon_title VARCHAR(100) NOT NULL, ".
"runoon_author VARCHAR(40) NOT NULL, ".
"submission_date DATE, ".
"PRIMARY KEY ( runoon_id ))ENGINE=InnoDB DEFAULT CHARSET=utf8; ";
mysqli_select_db( $conn, 'RUNOON' );
$retval = mysqli_query( $conn, $sql );
if(! $retval )
{
die('数据表创建失败: ' . mysqli_error($conn));
}
echo "数据表创建成功\n";
mysqli_close($conn);
?>
mysql> use RUNOON;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> show tables;
+------------------+
| Tables_in_RUNOON |
+------------------+
| runoon_tbl |
+------------------+
1 row in set (0.00 sec)
mysql> desc runoon_tbl;
+-----------------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-----------------+--------------+------+-----+---------+----------------+
| runoon_id | int(11) | NO | PRI | NULL | auto_increment |
| runoon_title | varchar(100) | NO | | NULL | |
| runoon_author | varchar(40) | NO | | NULL | |
| submission_date | date | YES | | NULL | |
+-----------------+--------------+------+-----+---------+----------------+
4 rows in set (0.00 sec)
mysql>
长按二维码关注公众号,查阅更多教程