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

约束条件
作用是限制如何给字段赋值
查看约束条件
mysql> desc 库名.表名;
mysql> desc db1.t9;

//如图所示,每列代表的含义:字段名 | 类型 | 空 | 键值 | 默认值 | 额外设置
mysql> insert into t9 values (null,null,null);
//如上图所示,约束条件允许为空(NULL),所以此处赋值的时候可以为空,null不区分大小写
mysql> select * from db1.t9;

mysql> insert into db1.t9(name,sex) values("lucy","girl");
mysql> select * from db1.t9;//t9表的约束条件里,第三字段默认值为NULL,也就是说当没有给第三字段赋值的时候,会以默认值填入表中,即如下图所示默认填入NULL

设置约束条件
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> insert into db2.t1(name) values("bob");//只给name字段赋值,剩下的字段由默认值赋值
mysql> select * from db2.t1;

mysql> insert into db2.t1 values("lucy","21","w"); //给字段赋值,就不会以默认值赋值了
mysql> select * from db2.t1;
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;
总结
约束条件 | 类型 |
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> 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> select * from db2.t1; //查看表内容,发现hobby字段自动添加了默认值

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

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

修改字段类型
基本用法
—— 修改的字段类型不能与已存储的数据冲突
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;

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

将字段name的类型变为varchar(15)
mysql> alter table db2.t1 modify name varchar(15) not null default ""; mysql> desc db2.t1;

修改字段名
基本用法
—— 也可以用来修改字段类型
mysql> alter table 库名.表名 change 源字段名 新字段名 类型(宽度) 约束条件;
注:也可以用来修改类型和约束条件,只需要写上新的类型和新的约束条件即可
mysql> desc db2.t1;

将字段名email修改为mail
mysql> alter table db2.t1 change email mail varchar(50);
mysql> desc db2.t1;

将字段名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> alter table 库名.表名 drop 字段名;
mysql> alter table db2.t1 drop email; //删除库db2中表t1的字段email mysql> desc db2.t1; //没有字段email,已被删除

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

修改表名
基本用法
mysql> alter table 库名.表名 rename 新表名;
库名.新表名;
mysql> use db2;
mysql> show tables;

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

mysql> select * from stuinfo;

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。
MySQL事务日志的特征有哪些
- 上一篇
- MySQL事务日志的特征有哪些
- 下一篇
- 如何下载 Surface Laptop 5 的驱动程序
-
- 数据库 · MySQL | 1小时前 |
- 视图的优缺点分析:MySQL视图利与弊
- 294浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- MySQL数值函数大全及使用技巧
- 117浏览 收藏
-
- 数据库 · MySQL | 4天前 |
- 三种登录MySQL方法详解
- 411浏览 收藏
-
- 数据库 · MySQL | 4天前 |
- MySQL数据备份方法与工具推荐
- 420浏览 收藏
-
- 数据库 · MySQL | 5天前 |
- MySQL数据备份方法与工具推荐
- 264浏览 收藏
-
- 数据库 · MySQL | 5天前 |
- MySQL索引的作用是什么?
- 266浏览 收藏
-
- 数据库 · MySQL | 6天前 |
- MySQL排序原理与实战应用
- 392浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQLwhere条件查询技巧
- 333浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL常用数据类型有哪些?怎么选更合适?
- 234浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL常用命令大全管理员必学30条
- 448浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL高效批量插入数据方法大全
- 416浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL性能优化技巧大全
- 225浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3186次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3398次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3429次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4535次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3807次使用
-
- MySQL主从切换的超详细步骤
- 2023-01-01 501浏览
-
- Mysql-普通索引的 change buffer
- 2023-01-25 501浏览
-
- MySQL高级进阶sql语句总结大全
- 2022-12-31 501浏览
-
- Mysql报错:message from server: * is blocked because of many
- 2023-02-24 501浏览
-
- 腾讯云大佬亲码“redis深度笔记”,不讲一句废话,全是精华
- 2023-02-22 501浏览

