首页 > 数据库 > MySQL > 正文

MySQL表结构实例解析

2024-07-24 12:33:20
字体:
来源:转载
供稿:网友
  这篇文章主要介绍“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> 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;
 
  注:
 
  如果表中这个字段类型下面的字段已经有值了,那么修改的类型与约束不能与字段里面已经存储的数据发生冲突,如果发生冲突则不允许修改。比如,有一个字段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;
 
  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;

  将字段名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表结构实例分析”的内容就介绍到这里了,感谢大家的阅读。

(编辑:武林网)

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表