首頁 >資料庫 >mysql教程 >歸納詳解MySQL知識點之表結構

歸納詳解MySQL知識點之表結構

WBOY
WBOY轉載
2022-03-04 17:12:122454瀏覽

本篇文章為大家帶來了關於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          //設定預設值,預設值為

    default          //設定預設值,缺省為

    ULL
  • #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;

總結

##外部鍵   foreign key#全文索引   fulltext

約束條件

類型

Null(是否允許為空白null)

預設允許   null


不允許空白   not null

Key(鍵值)

普通索引   index


唯一索引   unique


主鍵   primary key





#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;

推荐学习:mysql视频教程

以上是歸納詳解MySQL知識點之表結構的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除