千家信息网

MySQL表结构实例分析

发表于:2025-02-23 作者:千家信息网编辑
千家信息网最后更新 2025年02月23日,这篇文章主要介绍"MySQL表结构实例分析"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"MySQL表结构实例分析"文章能帮助大家解决问题。约束条件作用是限制如
千家信息网最后更新 2025年02月23日MySQL表结构实例分析

这篇文章主要介绍"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 nullmysql> 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,drinkmysql> 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 valuemysql> 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的字段emailmysql> 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;

关于"MySQL表结构实例分析"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。

字段 类型 条件 宽度 数据 位置 结构 原样 冲突 存储 实例 实例分析 分析 字符 时候 知识 索引 部分 内容 动作 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 小乐解说我的世界服务器 镇街网络安全自查报告 数据库搜索是什么问题 多功能网络技术开发口碑推荐 web服务器哪三部分组成 易县国培软件开发服务部 优惠的ftp服务器托管公司 查询成绩最高前五名数据库 济南地区联想服务器代理测评 数据中心要解决服务器散热问题 分布式网络安全大脑 数据库分库设计 推进网络安全 宣传标语 从服务器返回一个参照 机电一体化软件开发工程师 网络安全哪个公司做的最好 网络安全对软件工程的认识 房产原值包括电脑服务器吗 我的世界网易版黏土云服务器 数据库eshop 十大网络安全事件评比 大数据实时多维检索数据库 表格怎么根据日期选取数据库 数据库查询命令结构 神话数据库漫画全集免费 制作一台ntp时间同步服务器 成都软件开发在哪里上班 图片转换access数据库 深圳中辉互联网科技怎么样 网络安全对软件工程的认识
0