前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >第三章《数据表的基本操作》

第三章《数据表的基本操作》

作者头像
全栈程序员站长
发布2021-06-08 21:24:35
1.4K0
发布2021-06-08 21:24:35
举报

1.关于表 表示数据库存储数据的基本单位。一个表可以包含若干个字段或者是记录。表的操作包括创建表、修改表、删除表。创建数据表的过程是规定数据列的属性的过程,同时也是实施数据完整性约束的过程。 1.创建表: 数据表属于数据库,在创建数据表之前,应该使用“USE <数据库名>”移动到指定的数据库下。 如果没有选择数据库,创建表时会报错; 创建表的语法: CREATE TABLE table_name ( 字段1 数据类型 [完整性约束条件], 字段2 数据类型 [完整性约束条件], );

mysql> create table hahaha //创建表 -> ( -> id INT(10), -> name VARCHAR(25), -> sex VARCHAR(10) -> );

mysql> show tables; //查看表 ±————-+ | Tables_in_hy | ±————-+ | hahaha | ±————-+

mysql> desc hahaha; //查看表的结构 ±——±————±—–±—-±——–±——+ | Field | Type | Null | Key | Default | Extra | ±——±————±—–±—-±——–±——+ | id | int(10) | YES | | NULL | | | name | varchar(25) | YES | | NULL | | | sex | varchar(10) | YES | | NULL | | ±——±————±—–±—-±——–±——+

2.什么是完整型约束条件? 完整性约束条件对字段进行限制,要求用户只能向字段中写入符合条件的数据,如果不满足约束条件数据库将不执行该数据的写入操作。

常用的约束条件: PRIMARY KEY(primary key): 标识该字段为该表的主键,可以唯一的标识数据。(特点:非空、唯一); FOREIGN KEY(foreign key): 表示该字段为该表的外键,是与之联系的某表的主键。 NOT NULL(not null): 非空,标识该字段的值不能为空; UNIQUE(unique): 唯一,标识该字段的值是唯一的; AUTO_INCREMENT(auto_increment): 自增,表示该字段的值自动增加。一般对应数据类型INT,默认从1开始递增 DEFAULT(default):为该字段设置默认值; UNSIGNED(unsigned):无符号,值从0开始,无负数; ZEROFILL(zerofill):零填充,当数据的显示长度不够的时候可以使用在前面补0的效果填充值指定长度, 字段会自动添加UNSIGNED约束;

2.1使用主键约束 主键是一个特殊字段,每一个表只能设置一个主键,主键约束要求主键列的数据唯一,可以唯一的标识表中的数据并且不能为空(非空且唯一)。 添加主键的语法: 1.在创建数据表的时候设置主键; (1)单字段主键; 语法:字段名 数据类型 PRIMARY KEY mysql> create table hahaha2 -> ( -> id int(11) PRIMARY KEY, -> name VARCHAR(10), -> sex VARCHAR(10) -> );

mysql> desc hahaha2; ±——±————±—–±—-±——–±——+ | Field | Type | Null | Key | Default | Extra | ±——±————±—–±—-±——–±——+ | id | int(11) | NO | PRI | NULL | | | name | varchar(10) | YES | | NULL | | | sex | varchar(10) | YES | | NULL | | ±——±————±—–±—-±——–±——+

语法:在所有字段都规定好了之后,在所有字段的最后面来设置主键 字段1 数据类型 [完整性约束], 字段2 数据类型 [完整性约束], 字段N 数据类型 [完整性约束], [CONSTRAINT<主键名>] PRIMARY KEY (字段1,字段2,字段3,…)

在这里插入图片描述
在这里插入图片描述

2.用修改表的方法也可以添加主键: ALTER TABLE 表名 ADD PRIMARY KEY (字段名)

在这里插入图片描述
在这里插入图片描述

2.3使用外键: 外键用来在两个数据表之间建立连接,它可以是一列,也可以是多列; 语法: 在创建表的时候添加 字段1 数据类型 [完整性约束], 字段2 数据类型 [完整性约束], 字段N 数据类型 [完整性约束], [CONSTRAINT <外键名>]FOREIGN KEY (字段1,字段2,字段N) REFERENCES 主表(主键列)

在这里插入图片描述
在这里插入图片描述

修改表的方式添加外键: ALTER TABLE 子表名 ADD CONSTRAINT 外键名 FOREIGN KEY (字段) REFERENCES 父表名 (父表主键列)

在这里插入图片描述
在这里插入图片描述

注意; 1.关联的父表列,一定是父表的主键列 2.关联的父表如果为联合主键是,先关联联合主键中的第一个字段 3.关联父表时,被关联的外键的数据类型要和父表主键的数据类型一致,否则关联失败 4.关联父表时,父表和子表的存储引擎必须为InnoDB,MyISAM引擎不支持外键功能。 5.要避免书写错误 6.如果两个表之间有外键关联,如果我们想要删除父表,必须先解除外键的关系,或者先删除掉子表, 否则无法删除父表

2.4使用非空约束 非空约束指字段的值不能为空 语法: 在创建表时 字段名 数据类型 NOT NULL

在这里插入图片描述
在这里插入图片描述

2.5 唯一约束: 给字段的值添加唯一属性,添加之后,该字段不能插入重复的值 语法; 1.直接在创建表时,再要设置唯一性的字段数据类型后添加UNIQUE 2.在所有字段后面添加:[CONSTRAINT 约束名] UNIQUE (字段);

在这里插入图片描述
在这里插入图片描述

2.6使用默认约束条件; 默认约束是给字段设置默认值,如果在插入数据的时候没有给改列赋值,则系统会自动将默认值插入到该列。 添加语法: 字段名 数据类型 DEFAULT(默认值)

在这里插入图片描述
在这里插入图片描述

2.7 设置自增约束 要求字段的数据类型为数字类型, 语法; 字段 数据类型 AUTO_INCREMENT

在这里插入图片描述
在这里插入图片描述

3.修改数据表; 3.1修改表名 一个数据库里的每一个数据表的名称都是唯一的。 语法: ALTER TABLE <旧表名> RENAME [TO] <新表名>; 例如:

在这里插入图片描述
在这里插入图片描述

注意: 还可以通过修改表名的语法把A库里面的teacher表移动到B库里。 ALTER TABLE teacher RENAME TO B.teacher 例子:

在这里插入图片描述
在这里插入图片描述

3.2 修改字段名; 语法; ALTER TABLE <表名> CHANGE <旧字段名> <新字段名> <新的数据类型>; mysql> DESC teacher; ±——±————±—–±—-±——–±——+ | Field | Type | Null | Key | Default | Extra | ±——±————±—–±—-±——–±——+ | name | varchar(20) | NO | PRI | | | | sex | varchar(20) | YES | | NULL | | | age | int(11) | YES | | NULL | | ±——±————±—–±—-±——–±——+ 3 rows in set (0.00 sec)

mysql> ALTER TABLE teacher CHANGE age id INT(11); Query OK, 0 rows affected (0.01 sec) Records: 0 Duplicates: 0 Warnings: 0

mysql> DESC teacher; ±——±————±—–±—-±——–±——+ | Field | Type | Null | Key | Default | Extra | ±——±————±—–±—-±——–±——+ | name | varchar(20) | NO | PRI | | | | sex | varchar(20) | YES | | NULL | | | id | int(11) | YES | | NULL | | ±——±————±—–±—-±——–±——+ 3 rows in set (0.00 sec)

3.3修改字段的数据类型: 语法: ALTER TABLE 表名 MODIFY <字段名> <新数据类型>; 例子; mysql> DESC teacher; ±——±————±—–±—-±——–±——+ | Field | Type | Null | Key | Default | Extra | ±——±————±—–±—-±——–±——+ | name | varchar(20) | NO | PRI | | | | sex | varchar(20) | YES | | NULL | | | id | int(11) | YES | | NULL | | ±——±————±—–±—-±——–±——+ 3 rows in set (0.00 sec)

mysql> ALTER TABLE teacher MODIFY id VARCHAR(20); Query OK, 0 rows affected (0.04 sec) Records: 0 Duplicates: 0 Warnings: 0

mysql> DESC teacher; ±——±————±—–±—-±——–±——+ | Field | Type | Null | Key | Default | Extra | ±——±————±—–±—-±——–±——+ | name | varchar(20) | NO | PRI | | | | sex | varchar(20) | YES | | NULL | | | id | varchar(20) | YES | | NULL | | ±——±————±—–±—-±——–±——+ 3 rows in set (0.00 sec)

3.4添加新的字段 语法; ALTER TABLE <表名> ADD <新字段名> <数据类型> <约束条件> [first/after 已存在的字段名];

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.5修改字段的摆列位置; 语法: alter table <表名> modify <字段名> <数据类型> first/after <字段2>

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.6删除字段: 语法: alter table <表名> drop 字段名;

在这里插入图片描述
在这里插入图片描述

3.7 创建表的时候选择不同的存储引擎; 语法: create table <表名> ( 字段1 数据类型 约束条件, 字段2 数据类型 约束条件, 。。。 )ENGINE=InnoDB/MyISAM;

查看表详细结构;

在这里插入图片描述
在这里插入图片描述

3.8更改表的存储引擎; alter table <表名> ENGINE=更改后的引擎;

在这里插入图片描述
在这里插入图片描述

3.9 删除数据表; 语法 : drop table 表1,表2,表N… [IF EXISTS]:不加这个,如果我们要删除的表不存在就会报错,加上呢,不存在也会执行删除操作,不会返回错误信息

注意:如果我们要删除的表是另一个设置了外键的表的父表,无法直接删除,我们需要先删除外键或者是把子表删掉,才可以删除这个表;

在这里插入图片描述
在这里插入图片描述

3.10 删除表的外键约束: 语法: alter table <表名> drop foreign key <外键名> ; 注意:如果没有设置外键名,外键名就是字段名;

3.11 删除表的主键约束; 语法: alter table <表名> drop PRIMARY KEY;

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/101975.html原文链接:

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档