MySQL:管理和操作数据表

数据表是数据库的重要组成部分,每一个数据库都是由若干个数据表组成的。没有数据表就无法在数据库中存放数据。MySQL数据表的管理和操作是数据库管理员和开发人员日常工作中不可或缺的一部分。

创建数据表 CREATE

创建数据表的过程是规定数据列的属性的过程,同时也是实施数据完整性(包括实体完整性、引用完整性和域完整性)约束的过程。

基本语法

在MySQL中,可以使用 CREATE TABLE 语句创建表:

CREATE TABLE (IF NOT EXISTS)<表名> (表定义选项)(表选项)(分区选项);
'''
`[表定义选项]`的格式为:  <列名1> <类型1> [,…] <列名n> <类型n>
'''

CREATE TABLE 命令语法比较多,其主要是由
表创建定义(create-definition)、
表选项(table-options)
分区选项(partition-options)所组成的。

使用CREATE TABLE创建表时,必须指定以下信息:

  • 要创建的表的名称不区分大小写,不能使用SQL语言中的关键字,如DROP
    ALTERINSERT等。

  • 数据表中每个列(字段)的名称和数据类型,创建多个列要用逗号隔开。

使用说明
  • CREATE TABLE:用于创建给定名称的表,必须拥有表CREATE的权限

  • <表名>:指定要创建表的名称,必须符合标识符命名规则。表名称被指定为 db_name.tbl_name,以便在特定的数据库中创建表。无论是否有当前数据库,都可以通过这种方式创建。

  • 在当前数据库中创建表时,可以省略 db-name。如果使用加引号的识别名,则应对数据库和表名称分别加引号。例如,‘mydb’.‘mytbl’ 是合法的,但 ‘mydb.mytbl’ 不合法。

  • <表定义选项>:表创建定义,由列名(col_name)、列的定义(column_definition)以及可能的空值说明、完整性约束或表索引组成。

  • 默认的情况是,表被创建到当前的数据库中。若表已存在、没有当前数据库或者数据库不存在,则会出现错误。

示例
CREATE TABLE demo(id INT NOT NULL AUTO_INCREMENT,name VARCHAR(10) (DEFAULT '匿名' COMMENT '姓名',···(CONSTRAINT fk_demo0_demo FOREIGN KEY (demoID) REFERENCES demo(id)) '''建立名为fk_demo0_demo的外键约束,demo为父表,其主键demoID被demo关联'''
)ENGINE=INNODB DEFAULT CAHRSET=utf8;
# “COMMENT” 关键字后跟一个字符串来为表添加注释,提供关于表的额外信息

修改数据表 ALTER

修改数据表的前提是数据库中已经存在该表。修改表指的是修改数据库中已经存在的数据表的结构。

在 MySQL 中可以使用 ALTER TABLE 语句来改变原有表的结构,例如增加或删减列、更改原有列类型、重新命名列或表等:

ALTER TABLE <表名> <修改选项> '''
修改选项的语法格式如下:| ADD COLUMN <列名> <类型> [完整性约束]
| CHANGE COLUMN <旧列名> <新列名> <新列类型>  
| ALTER COLUMN <列名> { SET DEFAULT <默认值> | DROP DEFAULT }  
| MODIFY COLUMN <列名> <类型>  
| DROP COLUMN <列名> [CASCADE|RESTRICT] 
| ADD CONSTRINT<完整性约束名> <完整性约束>
| DROP CONSTRINT<完整性约束名> [CASCADE|RESTRICT] 
| RENAME TO <新表名>  
| CHARACTER SET <字符集名>  
| COLLATE <校对规则名> '''
修改表名 RENAME
ALTER TABLE <旧表名> RENAME [TO] <新表名>#TO 为可选参数,使用与否不影响结果'''示例'''
ALTER TABLE student RENAME TO student_info;

修改表名并不修改表的结构,因此修改名称后的表和修改名称前的表的结构是相同的。

注意事项:

  • 在重命名表时,确保新的表名在数据库中是唯一的,以避免与其他表重名。

  • 如果表有外键关联或被其他对象引用,需要确保相应的关联和引用也进行了更新。

修改存储引擎 ENGINE
ALTER TABLE [表名] ENGINE = [新引擎];

存储引擎的更换可能会影响表的性能、事务支持以及其他功能。在更换存储引擎之前,确保了解新存储引擎的特性和限制,并在生产环境中进行充分的测试。

另外,不同的数据库管理系统支持不同的存储引擎,并且某些存储引擎可能不可用或受到特定数据库版本的限制。

修改字符集 CHARACTER SET

MySQL 通过 ALTER TABLE 语句来实现表字符集的修改:

ALTER TABLE 表名 [DEFAULT] CHARACTER SET <字符集名> [DEFAULT] COLLATE <校对规则名>;# DEFAULT 为可选参数,使用与否均不影响结果。'''示例'''
ALTER TABLE student CHARACTER SET gb2312 
DEFAULT COLLATE gb2312_chinese_ci;#将数据表 student 的字符集修改为 gb2312,校对规则修改为 gb2312_chinese_ci

通过修改表的字符集和排序规则,可以确保表能够存储和处理特定编码的数据。这对于需要支持不同语言或从不同字符集的数据库迁移数据时非常有用。

需要注意的是,修改表的字符集和排序规则可能会影响现有数据和查询的行为。在进行这些修改之前,请务必备份数据并仔细考虑其影响。

添加字段 ADD

MySQL 数据表是由行和列构成的,通常把表的 “列” 称为字段(Field)
把表的 “行” 称为记录(Record)。随着业务的变化,可能需要在已有的表中添加新的字段。

MySQL 允许在开头、中间和结尾处添加字段。一个完整的字段包括字段名、数据类型和 [[MySQL Constraint|约束条件]]

在末尾添加字段 ADD

末尾添加字段的语法格式如下:

ALTER TABLE <表名> ADD <新字段名><数据类型><约束条件>;
  • <表名> 为数据表的名字;
  • <新字段名> 为所要添加的字段的名字;
  • <数据类型> 为所要添加
ALTER TABLE student ADD new_data VARCHAR(10);
在开头添加字段 ADD…FIRST

在开头位置(第一列的前面)添加新字段,语法格式如下:

ALTER TABLE <表名> ADD <新字段名> <数据类型> [约束条件] FIRST;'''示例'''alter table student ADD new_data INT(4) FIRST;
在中间位置添加字段 ADD…AFTER

在中间位置(指定的字段之后)添加字段,语法格式如下:

ALTER TABLE <表名> ADD <新字段名> <数据类型> [约束条件] AFTER 
<已经存在的字段名>;# AFTER 的作用是将新字段添加到某个已有字段后面。'''示例'''
ALTER TABLE student brand_new_demo INT(4) AFTER new_data;

只能在某个已有字段的后面添加新字段,不能在它的前面添加新字段。

修改字段
修改字段名 CHANGE COLUMN

MySQL 中修改表字段名称的语法规则如下:

ALTER TABLE <表名> CHANGE COLUMN <旧字段名><新字段名> <新数据类型>
  • 旧字段名:指修改前的字段名;

  • 新字段名:指修改后的字段名;

  • 新数据类型:指修改后的数据类型,如果不需要修改字段的数据类型,可以将新数据类型设置成与原来一样,但数据类型不能为空。

  • CHANGE 也可以只修改数据类型,实现和 MODIFY 同样的效果,方法是将 SQL 语句中的 “新字段名”和“旧字段名”设置为相同的名称,只改变“数据类型”

  • 由于不同类型的数据在机器中的存储方式及长度并不相同,修改数据类型可能会影响数据表中已有的数据记录,因此,当数据表中已经有数据时,不要轻易修改数据类型

"""示例"""
ALTER TABLE student CHANGE old new INT(4);
ALTER TABLE student CHANGE old old INT(4);
ALTER TABLE student CHANGE old new VARCHAR(10);
修改字段数据类型 MODIFY

修改字段的数据类型就是把字段的数据类型转换成另一种数据类型。

在 MySQL 中修改字段数据类型的语法规则如下:

ALTER TABLE <表名> MODIFY <字段名> <数据类型>
  • 表名:指要修改数据类型的字段所在表的名称;
  • 字段名:指需要修改的字段;
  • 数据类型:指修改后字段的新数据类型。
ALTER TABLE student MODIFY _data_ INT(4);'''等价于'''ALTER TABLE student CHANGE _data_ _data_ INT(4);
更换字段位置 MODIFY AFTER

将字段更换到目标字段后,在MySQL中无法使用BEFORE关键字,将字段更换到目标字段前,只能使用AFTER

ALTER TABLE table_name
MODIFY column_name column_datatype AFTER destinate_column_name
删除字段 DROP

删除字段是将数据表中的某个字段从表中移除,语法格式如下:

ALTER TABLE <表名> DROP <字段名>;
  • “字段名”指需要从表中删除的字段的名称。

删除数据表 DROP

对于不再需要的数据表,我们可以将其从数据库中删除。

在删除表的同时,表的结构和表中所有的数据都会被删除,因此在删除数据表之前最好先备份,以免造成无法挽回的损失

基本语法

使用 DROP TABLE 语句可以删除一个或多个数据表,语法格式如下:

DROP TABLE [IF EXISTS] 表名1 [ ,表名2, 表名3 ...]
  • 表名1, 表名2, 表名3 ... 表示要被删除的数据表的名称。DROP TABLE 可以同时删除多个表,只要将表名依次写在后面,相互之间用逗号隔开即可。

  • IF EXISTS 用于在删除数据表之前判断该表是否存在。如果不加 IF EXISTS,当数据表不存在时 MySQL 将提示错误,中断 SQL 语句的执行;加上 IF EXISTS 后,当数据表不存在时 SQL 语句可以顺利执行,但是会发出警告(warning)。

  • 用户必须拥有执行 DROP TABLE 命令的权限,否则数据表不会被删除

  • 表被删除时,用户在该表上的权限不会自动删除

删除被其他表关联的主表

数据表之间经常存在外键关联的情况,这时如果直接删除父表,会破坏数据表的完整性,也会删除失败。

当主表在存在外键约束时,不能被直接删除。

删除父表有以下两种方法:

  • 先删除与它关联的子表,再删除父表;但是这样会同时删除两个表中的数据。

  • 将关联表的外键约束取消,再删除父表;适用于需要保留子表的数据,只删除父表的情况:

ALTER TABLE tb_emp5 DROP FOREIGN KEY fk_emp4_emp5;
#解除子表 tb_emp5 的外键约束DROP TABLE tb_emp4;
#删除父表tb_emp4

查看表结构 DESC

创建完数据表之后,经常需要查看表结构(表信息)。在 MySQL 中,可以使用 DESCRIBESHOW CREATE TABLE 命令来查看数据表的结构。

DESCRIBE:以表格的形式展示表结构

DESCRIBE/DESC 语句会以表格的形式来展示表的字段信息,包括字段名、字段数据类型、是否为主键、是否有默认值等,语法格式如下:

DESCRIBE <表名>;

或简写成:

DESC <表名>;

![[MySQL DESC example.png]]

  • Null:表示该列是否可以存储 NULL 值。
  • Key:表示该列是否已编制索引。PRI 表示该列是表主键的一部分,
    UNI 表示该列是 UNIQUE 索引的一部分,MUL 表示在列中某个给定值允许出现多次。
  • Default:表示该列是否有默认值,如果有,值是多少。
  • Extra:表示可以获取的与给定列有关的附加信息,如 AUTO_INCREMENT 等。
SHOW CREATE TABLE:以SQL语句的形式展示表结构

SHOW CREATE TABLE命令会以 SQL 语句的形式来展示表信息。
DESCRIBE 相比,SHOW CREATE TABLE 展示的内容更加丰富,它可以查看表的存储引擎和字符编码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/388839.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网工内推 | 云运维工程师,最高19K,五险一金加补充医疗险

01 云计算运维工程师 &#x1f537;岗位职责 1、负责客户云计算解决方案的运维&#xff0c;负责云计算解决方案中云、虚拟化工作&#xff1b; 2、负责客户现场H3C产品的日常问题处理、变更维护、巡检、版本升级等工作&#xff0c;保障客户网络的稳定运行&#xff1b; 3、协调…

揭秘智能工牌:如何成为房企销售团队的数字化转型加速器

在这个竞争激烈的市场环境中&#xff0c;房企想要脱颖而出&#xff0c;不仅需要优质的产品和服务&#xff0c;更需要高效的销售团队。而销售团队的能力提升&#xff0c;离不开精细化管理和科技的赋能。DuDuTalk智能语音工牌&#xff0c;正是这样一款融合了AI技术与销售实战智慧…

Python中的yieId,比return更高效!

本文旨在深入探索"yield"的基本原理和实际应用&#xff0c;帮助你理解为什么它在Python编程中如此重要。 一、深入理解Yield "yield"与常用的"return"有本质的区别。"yield"不是真正返回一个值并退出函数&#xff0c;而是暂停函数执行…

springboot报错

springboot报错&#xff1a;g.yaml.snakeyaml.error.YAMLException: java.nio.charset.MalformedInputException: Input length 1 解决办法&#xff1a; file->settings 搜索encoding 然后选择File encodings 也可以直接找 File encodings 全部都更改整utf-8&#xff…

8.1IO进程线程

笔记 进程 一.多进程引入 1.1引入目的 程序员写程序时&#xff0c;一个程序可能由多个任务组成&#xff0c;如果使用的是单进程&#xff0c;或单任务&#xff0c;那么该任务执行阻塞时&#xff0c;其他任务就无法执行&#xff0c;必须等到该任务解除阻塞后&#xff0c;才能…

2024上半年热门内容透视 | 品牌种草解析

2024年上半年&#xff0c;小红书平台“考公上岸”、“不确定性”、“重养自己一遍”、“人生是旷野”、“原生家庭顶配”等话题热议之下&#xff0c;透露着消费者怎样的需求&#xff1f; 综合热门内容及小红书用户的分享发现&#xff0c;变数和不确定性成为新常态&#xff0c;消…

基于OpenCV C++的网络实时视频流传输——Windows下使用TCP/IP编程原理

1.TCP/IP编程 1.1 概念 IP 是英文 Internet Protocol &#xff08;网络之间互连的协议&#xff09;的缩写&#xff0c;也就是为计算机网络相互连接进行通信而设计的协议。任一系统&#xff0c;只要遵守 IP协议就可以与因特网互连互通。 所谓IP地址就是给每个遵循tcp/ip协议连…

3D打印随形透气钢:模具困气终结者

困气是模具经常遇到的问题&#xff0c;是制约生产效率与产品质量的关键因素之一。传统透气钢材料虽有所助益&#xff0c;但其在加工复杂度、形状适应性及性能均衡性上的局限性明显。在此背景下&#xff0c;3D打印技术的革新性应用——随形透气钢应运而生&#xff0c;为困气、排…

NLP与搜广推常见面试问题

1 auc指标 AUC的两种意义 一个是ROC曲线的面积另外一个是统计意义。从统计学角度理解&#xff0c;AUC等于随机挑选一个正样本和负样本时&#xff0c;模型对正样本的预测分数大于负样本的预测分数的概率。下图为搜广推场景下的一个计算auc的例子 2 GAUC指标 就是在推荐系统…

字符设备驱动基础—sys文件系统,udev介绍,驱动模块在内核空间注册设备

文章目录 sys文件系统介绍设计思想应用和功能 udev介绍主要功能工作原理使用 udevadm 工具 设备文件创建流程驱动程序的注册device_create函数详解示例代码效果图 sys文件系统介绍 sysfs 是 Linux 内核中的一种虚拟文件系统&#xff0c;它为用户空间和内核之间提供了一种统一的…

Kafka基本概念,工作流程介绍

1、消息队列与Kafka 1.1、Kafka简介 Kafka使用scala开发&#xff0c;支持多语言客户端&#xff08;c、java、python、go等&#xff09; Kafka最先由LinkedIn公司开发&#xff0c;之后成为Apache的顶级项目。 Kafka是一个分布式的、分区化、可复制提交的日志服务 LinkedIn使…

SpringBoot中的server.context-path

一、问题引入 书接上回&#xff0c;SpringBoot 在 idea中的 .idea和 .iml文件-CSDN博客&#xff0c;我在boot-test的测试项目中使用的 SpringBoot版本为 1.3.5.RELEASE&#xff0c;新项目 cps-task中使用的版本为 2.4.8&#xff0c;造成了连接异常&#xff0c;问题很好解决&…

(20240801)矿山固废基胶凝材料及混凝土中文期刊整理

一、篇名:固废 级别:EI + 篇名:固废混凝土/水泥/胶砂/胶凝材料 级别:EI

二叉树LeetCode热题

94.二叉树的中序遍历 题目 给定一个二叉树的根节点 root &#xff0c;返回 它的 中序 遍历 。 输入&#xff1a;root [1,null,2,3]输出&#xff1a;[1,3,2] 代码 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* …

基于python的百度迁徙迁入、迁出数据分析(六)

书接上回&#xff0c;苏州市我选取了2024年5月1日——5月5日迁入、迁出城市前20名并求了均值&#xff0c;从数据中可以看出苏州市与上海市的关系还是很铁的&#xff0c;都互为对方的迁入、迁出的首选且迁徙比例也接近4分之一&#xff0c;名副其实的老铁了&#xff1b; 迁出城市…

Springboot学习-day16

Springboot学习-day16 Springboot是spring家族中的一个全新框架&#xff0c;用来简化spring程序的创建和开发过程。在以往我们通过SpringMVCSpringMybatis框架进行开发的时候&#xff0c;我们需要配置web.xml&#xff0c;spring配置&#xff0c;mybatis配置&#xff0c;然后整…

鸿蒙应用框架开发【JS注入与执行】 Web

JS注入与执行 介绍 本示例基于H5游戏&#xff0c;通过arkui的button实现对游戏实现基本控制&#xff0c;展示webview的JS注入与执行能力&#xff0c;及native应用与H5的通信能力。 效果预览 使用说明 1.设备连接热点&#xff0c;可访问互联网。 2.打开应用&#xff0c;通过…

RuoYi-3.0代码审计

1 第三方组件漏洞审计 本项目使用Maven构建的。因此我们直接看pom.xml文件引入了哪些组件。通过IDEA打 开该若依&#xff0c;发现本项目采用了多模块方式。因此每个模块下都会有一个pom.xml&#xff0c;项目 最外层的pom.xml为父POM。我们可以通过 pom.xml 或者 External Libr…

【C语言】简易版扫雷游戏(数组、函数的练习)

目录 一、分析和设计 1.1、扫雷游戏的功能分析 1.2、文件结构设计&#xff08;多文件的练习&#xff09; 1.3、数据结构的设计 二、代码 三、效果展示 三、优化 一、分析和设计 1.1、扫雷游戏的功能分析 以在线版的扫雷游戏为参考&#xff0c;分析它的功能&#xff1a;扫…