视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
关于MySQL数据表操作的详解
2020-11-09 09:05:09 责编:小采
文档


mysql> USE D1;
Database changed

使用 USE D1;表示打开数据库D1,我们可以通过SELECT DATABASE();来查看当前打开的数据库:

mysql> SELECT DATABASE();
+------------+
| DATABASE() |
+------------+
| d1 |
+------------+1 row in set (0.00 sec)

创建数据表

CREATE TABLE [IF NOT EXISTS] table_name (
column_name datatype,
......
)

这个结构很简单,对于[IF NOT EXISTS],在第一篇 “MySQL基本操作” 已经说明,这里不赘述。

我们来创建一个数据表 table1:

mysql> CREATE TABLE table1(
 -> username VARCHAR(20),
 -> age TINYINT UNSIGNED,
 -> salary FLOAT(8,2) UNSIGNED
 -> );
Query OK, 0 rows affected (0.74 sec)

注意这里的UNSIGNED,表示无符号值,即是正数,可回顾 “MySQL基本数据类型” 查看,TINYINT UNSIGNED 表示 0 ~ 255 之间的数值。

这里提示创建成功,我们可以通过以下语句来验证一下:

SHOW TABLES [FROM db_name][LIKE 'pattern' | WHERE expr]

mysql> SHOW TABLES FROM D1;
+--------------+
| Tables_in_d1 |
+--------------+
| table1 |
+--------------+1 row in set (0.00 sec)

这里我们可以看到创建了table1这张表。

查看数据表结构

SHOW COLUMNS FROM tbl_name

mysql> SHOW COLUMNS FROM table1;
+----------+---------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+---------------------+------+-----+---------+-------+
| username | varchar(20) | YES | | NULL | |
| age | tinyint(3) unsigned | YES | | NULL | |
| salary | float(8,2) unsigned | YES | | NULL | |
+----------+---------------------+------+-----+---------+-------+3 rows in set (0.10 sec)

插入记录

创建完表之后就要写入数据了,通过以下语句插入记录:

INSERT [INTO] tbl_name [(col_name,...)] VALUE(val,...)

这里 [(col_name,...)] 为可选项,如果不添加,那么在VALUE里面的值必须一一与数据表的字段对应,否则无法插入,我们看一下:

mysql> INSERT table1 VALUE("LI",20,6500.50);
Query OK, 1 row affected (0.14 sec)

这里VALUE括号里面与table1的字段一一对应,分别为username=“LI”,age=20,salary=6500.50

下面我们再插入一条数据,但是没有对应:

mysql> INSERT table1 Value("Wang",25);
ERROR 1136 (21S01): Column count doesn't match value count at row 1

无法插入,因为没有给出salary的值。

通过添加 [(col_name,...)] 即可灵活插入数据:

mysql> INSERT table1(username,age) VALUE("Wang",25);
Query OK, 1 row affected (0.11 sec)

table1 与 VALUE 一一对应。

查找表数据

前面已经插入了两条数据,可以通过以下语句查找表数据:

SELECT expr,... FROM tbl_name

对于数据库的查找语句SELECT,内容比较多,后面文章会具体讲解,我们用一个简单的语句来查找表的内容:

mysql> SELECT * FROM table1
 -> ;
+----------+------+---------+
| username | age | salary |
+----------+------+---------+
| LI | 20 | 6500.50 |
| Wang | 25 | NULL |
+----------+------+---------+2 rows in set (0.00 sec)

注意MySQL语句是以“;”结尾,如果忘了写是无法执行语句的,在箭头后面添加分号即可;这里我们可以看到表里面有两条刚刚写入的数据。

表创建的基本约束

字段的NULL与NOT NULL

在创建表的时候,我们可以设定该字段是否可为空,如果不可为空,那么在插入数据时,则不能为空。

我们来创建一个数据表table2:

mysql> CREATE TABLE table2(
 -> username VARCHAR(20) NOT NULL,
 -> age TINYINT UNSIGNED NULL,
 -> salary FLOAT(8,2)
 -> );

这里username为非空,age为NULL,salary不写,我们来查看表结构:

mysql> SHOW COLUMNS FROM table2;
+----------+---------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+---------------------+------+-----+---------+-------+
| username | varchar(20) | NO | | NULL | |
| age | tinyint(3) unsigned | YES | | NULL | |
| salary | float(8,2) | YES | | NULL | |
+----------+---------------------+------+-----+---------+-------+3 rows in set (0.01 sec)

从这里我们可以看到,username的NULL为NO,其他两个字段为YES,对于可以为空的字段,写不写NULL都表示可以为空。

自动编号

AUTO_INCREMENT

auto_increment,auto自动,increment是增加的意思,组合起来表示自动增加,也就是可以自动按照从小到大的顺序编号。

  • 只能用于主键(主键表示表中数据的唯一表示,可以通过主键来区分表中的数据)

  • 默认情况下为1,增量为1

  • 下面来操作一下:

    mysql> CREATE TABLE table3(
     -> id SMALLINT UNSIGNED AUTO_INCREMENT,
     -> username VARCHAR(20)
     -> );
    ERROR 1075 (42000): Incorrect table definition; there can be only one auto column and it must be defined as a key

    报错,因为 id 没有设置为主键。

    设置主键

    PRIMARY KEY

  • 主键约束

  • 每张表只能存在一个主键

  • 主键保证记录的唯一性

  • 主键自动为NOT NULL

  • 那么我们添加主键,重新操作一次:

    mysql> CREATE TABLE table3(
     -> id SMALLINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
     -> username VARCHAR(20)
     -> );
    Query OK, 0 rows affected (0.42 sec)

    注意顺序,PRIMARY KEY 要放在最后。

    这样我们就创建成功,下面依次插入数据,并查看结果:

    mysql> INSERT table3(username) VALUES("Zhang");
    Query OK, 1 row affected (0.09 sec)
    
    mysql> INSERT table3(username) VALUES("Weng");
    Query OK, 1 row affected (0.07 sec)
    
    mysql> INSERT table3(username) VALUES("Chen");
    Query OK, 1 row affected (0.09 sec)
    
    mysql> SELECT * FROM table3;
    +----+----------+
    | id | username |
    +----+----------+
    | 1 | Zhang |
    | 2 | Weng |
    | 3 | Chen |
    +----+----------+3 rows in set (0.00 sec)

    我们可以看到id自动编号,从小到大一次依次编号。

    唯一约束

    UNIQUE KEY

  • 唯一约束

  • 唯一约束保证记录不可重复(唯一性)

  • 唯一约束可以为空值(NULL)

  • 可以有多个唯一约束

  • mysql> CREATE TABLE table4(
     -> id SMALLINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
     -> username VARCHAR(20) UNIQUE KEY,
     -> age TINYINT UNSIGNED
     -> );
    Query OK, 0 rows affected (0.43 sec)
    
    mysql> INSERT table4(username) VALUE("Li");
    Query OK, 1 row affected (0.11 sec)
    
    mysql> INSERT table4(username) VALUE("Li");
    ERROR 1062 (23000): Duplicate entry 'Li' for key 'username'
    
    mysql> INSERT table4(username) VALUE("Chen");
    Query OK, 1 row affected (0.10 sec)

    对于username我们设置为唯一约束,所以Li不可被重复创建,改为“Chen”即可。注意这里只是实验,在实际操作中,名字相同还是常有的,应该根据实际情况建立数据表。

    默认值DEFAULT

    通过 DEFAULT 来设置默认值,如果在插入数据时没给给出相应的值,那么就用默认的,下面的例子就是设置number的默认值为3,在插入数据的时候,因为没有给出number,所以默认为3。

    mysql> CREATE TABLE table5(
     -> number ENUM("1","2","3") DEFAULT "3",
     -> username VARCHAR(20)
     -> );
    Query OK, 0 rows affected (0.41 sec)
    
    mysql> INSERT table5(username) VALUES("Luo");
    Query OK, 1 row affected (0.10 sec)
    
    mysql> INSERT table5(username) VALUES("Fang");
    Query OK, 1 row affected (0.15 sec)
    
    mysql> SELECT * FROM table5;
    +--------+----------+
    | number | username |
    +--------+----------+
    | 3 | Luo |
    | 3 | Fang |
    +--------+----------+2 rows in set (0.00 sec)

    下载本文
    显示全文
    专题