站長資訊網
        最全最豐富的資訊網站

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

        本篇文章給大家帶來了關于mysql的相關知識,其中主要介紹了表結構包括了約束條件以及修改表結構的相關問題,希望對大家有幫助。

        歸納詳解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知識點之表結構

        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;

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

        總結

        約束條件

        類型

        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知識點之表結構

        • 在某一字段后面添加字段

        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知識點之表結構

        mysql> select * from db2.t1;     //查看表內容,發現hobby字段自動添加了默認值

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

        • 將字段添加到最前面

        mysql> alter table db2.t1 add class char(7) default "B180601" first;     //將字段class添加到最前面 mysql> desc db2.t1;

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

        mysql> select * from db2.t1; //class字段自動添加默認值

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

        修改字段類型

        • 基本用法

        —— 修改的字段類型不能與已存儲的數據沖突

        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;

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

        • 將字段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;

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

        • 將字段名email修改為mail

        mysql> alter table db2.t1 change email mail varchar(50);

        mysql> desc db2.t1;

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

        • 將字段名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知識點之表結構

        刪除字段

        • 基本用法

        mysql> alter table 庫名.表名 drop 字段名;

        mysql> alter table db2.t1 drop email;    //刪除庫db2中表t1的字段email mysql> desc db2.t1;    //沒有字段email,已被刪除

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

        mysql> select * from db2.t1; //字段email及其數據已被刪除

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

        修改表名

        • 基本用法

        mysql> alter table 庫名.表名 rename 新表名;

        庫名.新表名;

        mysql> use db2;

        mysql> show tables;

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

        mysql> alter table db2.t1 rename stuinfo; //將表名修改為stuinfo

        mysql> show tables;

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

        mysql> select * from stuinfo;

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

        推薦學習:mysql視頻教程

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 久久精品国产亚洲沈樵| 国产精品亚洲一区二区在线观看| 亚洲国产精品久久久久| 久久久久人妻精品一区二区三区| 精品综合久久久久久88小说| 一本一道久久精品综合| 91精品欧美综合在线观看| 无码精品A∨在线观看| 亚洲精品国产精品乱码不卞| 久久久久成人精品无码| 精品久久久久久无码免费| 成人免费精品网站在线观看影片 | 欧美精品一区二区蜜臀亚洲| 亚洲精品动漫人成3d在线| 久久久久这里只有精品 | 91精品视频观看| 凹凸69堂国产成人精品视频| 国产精品视频白浆免费视频| 无码人妻精品一区二区三区东京热| 亚洲日韩欧美制服精品二区| 亚洲国产综合精品中文字幕| 亚洲AV无码成人精品区大在线| 麻豆精品三级全部视频| 久久91精品综合国产首页| 国产精品亚洲美女久久久| 国产乱人伦偷精品视频| 国产精品嫩草影院久久| 国产精品 一区 在线| 国产精品久久久天天影视香蕉| 99久久亚洲综合精品网站| 99亚洲精品视频| 国产午夜精品一区二区三区小说| 国产午夜精品一区二区三区小说 | 日韩精品成人a在线观看| 亚洲AV蜜桃永久无码精品| 亚洲Av无码精品色午夜| 午夜精品久久久久久毛片| 国产美女精品一区二区三区| 91在线视频精品| 2020最新久久久视精品爱| 国产精品日韩深夜福利久久|