当前位置: 首页 > MySQL数据库

MySQL表结构实例分析

时间:2026-01-28 12:53:18

约束条件

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

    查看约束条件

      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及其数据已被删除

                                  修改表名

  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素