Mysql常用sql语句(2)- 操作数据表

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Mysql常用sql语句(2)- 操作数据表

测试必备的Mysql常用sql语句系列

https://www.cnblogs.com/poloyy/category/1683347.html

 

前言

针对数据表的操作语句叫做数据定义语言(DDL)  

 

数据表有哪些操作?

  • 创建数据表
  • 查看表结构
  • 查看数据表的创建语句
  • 复制数据表
  • 修改数据表
  • 删除数据表

简称“增删改查“,点击右边目录即可跳转哦! -------------->>>>>>>>>>

 

创建数据表


语法格式

CREATETABLE<表名> ( [表定义选项] )[表选项][分区选项];


知识点

  • 表名:两种写法,可以直接写数据表的名字 tbl_name ,也可以  db_name.tbl_name ,先指定数据库再指定数据表名;后者写法是为了:无论是否在当前数据库,也能通过这种方式在指定数据库下创建表
  • 表定义选项:一般都是 列名、列定义、默认值、约束、索引组成

 

实际栗子

# 创建数据表
CREATE TABLE yytest (
    id INT ( 10 ) NOT NULL UNIQUE PRIMARY KEY,
    uname VARCHAR ( 20 ) NOT NULL,
    sex VARCHAR ( 4 ),
    birth YEAR,
    department VARCHAR ( 20 ),
    address VARCHAR ( 50 ),
    yypolo VARCHAR ( 20 ) 
);
# 指定数据库,创建数据表
CREATE TABLE yytest.polotest (
    id INT ( 10 ) NOT NULL UNIQUE PRIMARY KEY AUTO_INCREMENT,
    stu_id INT ( 10 ) NOT NULL,
    c_name VARCHAR ( 20 ),
    istester VARCHAR ( 50 ),
    grade INT ( 10 ) 
);    


查看表结构


desc yytest.yytest;


执行结果

image.png


知识点

  • Null:表示该字段是否可以存储 NULL 值
  • Key:表示该字段是否已编制索引。PRI 表示主键,UNI 表示UNIQUE 索引,MUL 表示某个给定值允许出现多次
  • Default:表示该字段是否有默认值,如果有,值是多少
  • Extra:表示该字段的附加信息,如 AUTO_INCREMENT 等

 

查看数据表的创建语句


show createtable yytest;


执行结果

image.png

知识点

不仅可以查看创建表时的详细语句,而且可以查看存储引擎和字符编码

 

复制数据表


# 仅复制表结构
create table yytest2 like yytest;
# 复制表结构和数据
create table yytest3 as select  * from yytest;
# 仅复制表的指定字段结构
create table yytest4 as select id,uname,sex from yytest where 1<>1;
# 复制表的指定字段结构和数据
create table yytest5 as select id,uname,sex from yytest;
# 查看表创建语句:没有包含主键和自增
show create table yytest5;


知识点

  • 仅复制全部字段的结构直接加 like
  • 复制表不包含主键、索引、自增等

 

修改数据表


语法格式

ALTERTABLE<表名>[修改操作];

知识点


常用的修改表的操作


  • 修改表名
  • 修改字段数据类型或字段名
  • 增加和删除字段
  • 修改字段的排列位置
  • add、drop、change、modify、rename

 

修改表名


语法格式

ALTERTABLE<旧表名> RENAME [TO]<新表名>


注意

  • [TO] 加不加都行,不影响结果
  • 修改表名不影响表结构


实际栗子

altertable yytest2 rename to yytest22;

altertable yytest22 rename yytest22;

 

修改字段排列顺序


语法格式

ALTERTABLE<表名> MODIFY <字段名><数据类型>[FIRST|AFTER 已存在的字段名];


实际栗子

# 放在首位

altertable yytest22 modify sex int(2) first;


# 放在birth字段后面

altertable yytest22 modify sex int(2) after birth;

 

修改字段数据类型



语法格式

ALTERTABLE<表名> MODIFY <字段名><数据类型>;


实际栗子

# 修改字段数据类型

altertable yytest22 modify sex int(2);

 

修改字段名字


语法格式

ALTERTABLE<表名> CHANGE <旧字段><新字段><数据类型>;


实际栗子

# 修改字段名

altertable yytest22 change sex sexs int(2);


# 修改字段数据类型和字段名

altertable yytest22 change sexs sex varchar(4);

知识点

change不仅可以改字段名,也可以改字段数据类型

 

添加字段


语法格式

ALTERTABLE<表名>ADD<字段名><数据类型>  [约束条件][FIRST|AFTER 已存在的字段名];


实际栗子


# 添加字段

altertable yytest22 add  phone varchar(11);


# 添加字段到首位

altertable yytest22 add  phone varchar(11) notnulldefault2 first;


# 添加字段到某个字段后面

altertable yytest22 add  phone varchar(11) after sex;


 

删除字段


语法格式

ALTERTABLE<表名>DROP<字段名>


实际栗子

# 删除字段

altertable yytest22 drop  phone;

 

删除数据表


语法格式

DROPTABLE[IF EXISTS] 表名1 [ ,表名2, 表名3 ...]

可以看到跟删除库差不多


实际栗子

# 删除表如果存在

droptableifexists yytest,polotest

谨慎操作吧!!数据会清空哦!!

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
7天前
|
SQL 存储 缓存
MySQL进阶突击系列(02)一条更新SQL执行过程 | 讲透undoLog、redoLog、binLog日志三宝
本文详细介绍了MySQL中update SQL执行过程涉及的undoLog、redoLog和binLog三种日志的作用及其工作原理,包括它们如何确保数据的一致性和完整性,以及在事务提交过程中各自的角色。同时,文章还探讨了这些日志在故障恢复中的重要性,强调了合理配置相关参数对于提高系统稳定性的必要性。
|
5天前
|
SQL 关系型数据库 MySQL
MySQL 高级(进阶) SQL 语句
MySQL 提供了丰富的高级 SQL 语句功能,能够处理复杂的数据查询和管理需求。通过掌握窗口函数、子查询、联合查询、复杂连接操作和事务处理等高级技术,能够大幅提升数据库操作的效率和灵活性。在实际应用中,合理使用这些高级功能,可以更高效地管理和查询数据,满足多样化的业务需求。
26 3
|
8天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
10天前
|
SQL 存储 关系型数据库
MySQL进阶突击系列(01)一条简单SQL搞懂MySQL架构原理 | 含实用命令参数集
本文从MySQL的架构原理出发,详细介绍其SQL查询的全过程,涵盖客户端发起SQL查询、服务端SQL接口、解析器、优化器、存储引擎及日志数据等内容。同时提供了MySQL常用的管理命令参数集,帮助读者深入了解MySQL的技术细节和优化方法。
|
SQL 存储 缓存
一文搞懂MySQL中一条SQL语句是如何执行的
一文搞懂MySQL中一条SQL语句是如何执行的
|
存储 SQL 缓存
【Mysql】执行sql语句后,mysql都做了什么?
【Mysql】执行sql语句后,mysql都做了什么?
【Mysql】执行sql语句后,mysql都做了什么?
|
SQL 关系型数据库 MySQL
MySQL SQL语句给当前日期加一天和减一天
MySQL SQL语句给当前日期加一天和减一天
|
SQL 关系型数据库 MySQL
MYSQL 批量修改表前缀与删除数据表 sql 语句
MYSQL 批量修改表前缀与删除数据表 sql 语句
|
SQL 关系型数据库 MySQL
MySQL初级篇——常用SQL语句(大总结)(下)
MySQL初级篇——常用SQL语句(大总结)(下)
MySQL初级篇——常用SQL语句(大总结)(下)
|
SQL 存储 缓存
MySQL 简介及SQL 语句
MySQL 简介及SQL 语句
202 0
MySQL 简介及SQL 语句

热门文章

最新文章