>  기사  >  데이터 베이스  >  MySQL 지식 포인트의 테이블 구조를 자세히 요약하고 설명

MySQL 지식 포인트의 테이블 구조를 자세히 요약하고 설명

WBOY
WBOY앞으로
2022-03-04 17:12:122395검색

이 글은 mysql에 대한 관련 지식을 제공합니다. 제약 조건과 테이블 구조 수정 관련 문제를 주로 소개합니다. 모든 분들께 도움이 되기를 바랍니다.

MySQL 지식 포인트의 테이블 구조를 자세히 요약하고 설명

추천 학습: mysql 튜토리얼

Constraints

  • 이 기능은 필드에 값을 할당하는 방법을 제한하는 것입니다

View Constraints

  • mysql> 라이브러리 테이블 이름 ;

mysql> desc db1.t9;

//각 열의 의미는 다음과 같습니다. 필드 이름 | 공백 | 키 값 | 추가 설정 | , 제약 조건은 비어 있을 수 있으므로(NULL) 여기에 할당할 때 값이 비어 있을 수 있습니다. null은 대소문자를 구분하지 않습니다

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

mysql> select * from  db1.t9;
//t9 테이블의 제약 조건에서 세 번째 기본값은 필드가 NULL입니다. 이는 세 번째 필드가 지정되지 않은 경우 값을 지정하면 테이블이 기본값으로 채워집니다. 즉, 아래 그림과 같이 기본적으로 NULL이 채워집니다

제약조건 설정

    null //비워두기 허용(기본 설정)
  • null이 아님 //Null은 허용되지 않음
  • key                               ~       ​
  • mysql> insert into db1.t9(name,sex) values("lucy","girl");
    mysql> select * from db1.t9;

    // db2.t1 유형을 만듭니다. 이름 필드는 고정 길이 문자이며, 기본값은 0자입니다. 표시 효과는 아래 그림과 같습니다. 제약 조건은 음수(부호 없는)는 허용되지 않으며 기본값은 19로 설정됩니다. 여기서 기본값 설정은tinyint 유형의 범위를 초과해서는 안 됩니다. 즉, 기본값 설정은 255를 초과할 수 없습니다. sex 필드의 유형은 열거형이고 enum은 비워 둘 수 없으며 기본값은 m

  • mysql>
  • 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"
        -> );

    //이름 필드에만 값을 할당하고 나머지 필드에는 기본적으로 값이 할당됩니다.
  • mysql> insert into db2.t1(name) values("bob");
  • mysql> select * from db2.t1;

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

Summary

제약조건

Type

Null(null 허용 여부)기본 키 기본 키외래 키 외래 키기본값(기본값: 필드에 값을 할당하지 않음 기본값 할당 사용)기본값은 다음과 같습니다. 정의되지 않은 경우 null정의된 경우 기본값입니다(필드 유형과 일치하도록)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;

推荐学习:mysql视频教程

기본적으로 null 허용

null 아님


전체 텍스트 인덱스 fulltext




위 내용은 MySQL 지식 포인트의 테이블 구조를 자세히 요약하고 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제