当前位置:首页 > 文章列表 > 数据库 > MySQL > MySQL表结构实例分析

MySQL表结构实例分析

来源:亿速云 2023-04-25 22:51:42 0浏览 收藏

本篇文章向大家介绍《MySQL表结构实例分析》,主要包括,具有一定的参考价值,需要的朋友可以参考一下。

MySQL表结构实例分析

约束条件

  • 作用是限制如何给字段赋值

查看约束条件

  • mysql> desc 库名.表名;

mysql> desc db1.t9;

MySQL表结构实例分析

//如图所示,每列代表的含义:字段名 | 类型 | 空 | 键值 | 默认值 | 额外设置

mysql> insert into t9 values (null,null,null);

//如上图所示,约束条件允许为空(NULL),所以此处赋值的时候可以为空,null不区分大小写

mysql> select * from  db1.t9;

MySQL表结构实例分析

mysql> insert into db1.t9(name,sex) values("lucy","girl");
mysql> select * from db1.t9;

//t9表的约束条件里,第三字段默认值为NULL,也就是说当没有给第三字段赋值的时候,会以默认值填入表中,即如下图所示默认填入NULL

MySQL表结构实例分析

设置约束条件

  • null               //允许为空(默认设置)

  • not null         //不允许为null(空)

  • key                //键值类型

  • default          //设置默认值,缺省为NULL

  • extra             //额外设置

mysql> create database db2;
mysql> create table db2.t1(
    -> name char(10) not null default "",
    -> age tinyint unsigned default 19,
    -> sex enum("m","w") not null default "m"
    -> );

//创建一个表db2.t1,name字段的类型为定长char,约束条件是不允许为空,默认值为0个字符,显示效果入下图所示;age字段的类型是微小整数tinyint,约束条件是不允许为负数(unsigned),默认值设置为19,注此处的默认值设置不得超过tinyint类型的范围,即默认值的设置不能超过255;sex字段的类型为枚举,enum为单选,约束条件是不允许为空,默认值设置为m;

mysql> desc db2.t1;

MySQL表结构实例分析

mysql> insert into db2.t1(name) values("bob");

//只给name字段赋值,剩下的字段由默认值赋值

mysql> select * from db2.t1;

MySQL表结构实例分析

mysql> insert into db2.t1 values("lucy","21","w");     //给字段赋值,就不会以默认值赋值了
mysql> select * from db2.t1;

MySQL表结构实例分析

mysql> insert into db2.t1 values(null,null,null);    
  //错误提示,name字段不允许为空;name和sex字段都不能为空
ERROR 1048 (23000): Column 'name' cannot be null
mysql> insert into db2.t1 values("null",null,"w");     
//"null"的意思不再是空,仅仅是字符null,没有空的含义了,所以可以给字段赋值
mysql> insert into db2.t1 values("",null,"w");     
//""为0个字符,和空不一样,也可以给字段赋值
mysql> select * from db2.t1;

MySQL表结构实例分析

总结

约束条件

类型

Null(是否允许为空null)

默认允许   null


不允许为空   not null

Key(键值)

普通索引   index


唯一索引   unique


主键   primary key


外键   foreign key


全文索引   fulltext

Default(默认值:不给字段赋值使用默认值赋值)

默认不定义时是 null


定义时是 default(要与字段类型匹配)

Extra(额外设置:默认都没有额外设置)


修改表结构

语法结构

  • 用法

mysql> alter table 库名.表名 执行动作;

  • 执行动作

add          添加字段

modify     修改字段类型

change     修改字段名

drop         删除字段

rename     修改表名

添加新字段

  • 用法

—— 新字段默认添加在字段末尾

mysql> alter table 库名.表名 add 字段名 类型(宽度) 约束条件;

add 字段名 类型 [约束条件] after 字段名;

add 字段名 类型 [约束条件] first;

  • 不指定位置添加字段

mysql> alter table db2.t1 add email varchar(50);     //不指定添加字段的位置,默认就在末尾
mysql> desc db2.t1;

MySQL表结构实例分析

  • 在某一字段后面添加字段

mysql> alter table db2.t1 add hobby set("eat","drink","play","happy") not null default "eat,drink" after age;    //指定添加位置在字段age之后,条件设置不允许为空,并设置默认值为eat,drink
mysql> desc db2.t1;

MySQL表结构实例分析

mysql> select * from db2.t1;     //查看表内容,发现hobby字段自动添加了默认值

MySQL表结构实例分析

  • 将字段添加到最前面

mysql> alter table db2.t1 add class char(7) default "B180601" first;     //将字段class添加到最前面
mysql> desc db2.t1;

MySQL表结构实例分析

mysql> select * from db2.t1;     //class字段自动添加默认值

MySQL表结构实例分析

修改字段类型

  • 基本用法

—— 修改的字段类型不能与已存储的数据冲突

mysql> alter table 库名.表名 modify 字段名 类型(宽度) 约束条件;

modify 字段名 类型 [约束条件] after 字段名;

modify 字段名 类型 [约束条件] first;

注:

如果表中这个字段类型下面的字段已经有值了,那么修改的类型与约束不能与字段里面已经存储的数据发生冲突,如果发生冲突则不允许修改。比如,有一个字段name,里面存储了一个数据为bob,那么把字段的类型(宽度)改成char(1),则会修改失败,因为bob的宽度为3,如果将字段的类型(宽度)改为char(1),则源数据bob就存不下了,由于已存储的数据优先,所以就不能进行修改;

修改字段的类型时要注意,不修改的部分要原样进行抄写,如果不修改的部分不原样抄写,那就相当于对其进行还原即使用默认配置。比如有一个字段name,他的类型是char(10),约束条件是不允许为空,默认值是"",现在要将其类型宽度改为char(20),其余没修改的部分没有在命令中进行原样抄写,那么输出结果该字段的约束条件会变为默认情况,即允许为空,默认值为NULL。改变字段位置的时候也一样。

mysql> desc db2.t1;

MySQL表结构实例分析

  • 将字段age的位置修改到字段class的后面

mysql> alter table db2.t1 modify age tinyint unsigned default 19 after class;     //除了对字段age的位置进行了修改,其余不修改的地方如:类型(宽度)、约束条件进行原样抄写

mysql> desc db2.t1;

MySQL表结构实例分析

  • 将字段name的类型变为varchar(15)

mysql> alter table db2.t1 modify name varchar(15) not null default "";
mysql> desc db2.t1;

MySQL表结构实例分析

修改字段名

  • 基本用法

—— 也可以用来修改字段类型

mysql> alter table 库名.表名 change 源字段名 新字段名 类型(宽度) 约束条件;

注:也可以用来修改类型和约束条件,只需要写上新的类型和新的约束条件即可

mysql> desc db2.t1;

MySQL表结构实例分析

  • 将字段名email修改为mail

mysql> alter table db2.t1 change email mail varchar(50);

mysql> desc db2.t1;

MySQL表结构实例分析

  • 将字段名mail修改为email,并修改约束条件

mysql> alter table db2.t1 change mail email varchar(50) not null default "njw@163.com";     //出现错误,因为源数据中,mail字段中的值为NULL,如果将约束条件修改为not null,那么就与源数据发生冲突,所以修改失败
ERROR 1138 (22004): Invalid use of NULL value
mysql> alter table db2.t1 change mail email varchar(50) default "njw@163.com";
mysql> desc db2.t1;

MySQL表结构实例分析

删除字段

  • 基本用法

mysql> alter table 库名.表名 drop 字段名;

mysql> alter table db2.t1 drop email;    //删除库db2中表t1的字段email
mysql> desc db2.t1;    //没有字段email,已被删除

MySQL表结构实例分析

mysql> select * from db2.t1;    //字段email及其数据已被删除

MySQL表结构实例分析

修改表名

  • 基本用法

mysql> alter table 库名.表名 rename 新表名;

库名.新表名;

mysql> use db2;

mysql> show tables;

MySQL表结构实例分析

mysql> alter table db2.t1 rename stuinfo;     //将表名修改为stuinfo

mysql> show tables;

MySQL表结构实例分析

mysql> select * from stuinfo;

MySQL表结构实例分析

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。

版本声明
本文转载于:亿速云 如有侵犯,请联系study_golang@163.com删除
MySQL事务日志的特征有哪些MySQL事务日志的特征有哪些
上一篇
MySQL事务日志的特征有哪些
如何下载 Surface Laptop 5 的驱动程序
下一篇
如何下载 Surface Laptop 5 的驱动程序
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 笔灵AI生成答辩PPT:高效制作学术与职场PPT的利器
    笔灵AI生成答辩PPT
    探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
    23次使用
  • 知网AIGC检测服务系统:精准识别学术文本中的AI生成内容
    知网AIGC检测服务系统
    知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
    35次使用
  • AIGC检测服务:AIbiye助力确保论文原创性
    AIGC检测-Aibiye
    AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
    37次使用
  • 易笔AI论文平台:快速生成高质量学术论文的利器
    易笔AI论文
    易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
    46次使用
  • 笔启AI论文写作平台:多类型论文生成与多语言支持
    笔启AI论文写作平台
    笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
    40次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码