亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

  • 站長(zhǎng)資訊網(wǎng)
    最全最豐富的資訊網(wǎng)站

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    本篇文章給大家?guī)砹岁P(guān)于mysql的相關(guān)知識(shí),其中主要介紹了表結(jié)構(gòu)包括了約束條件以及修改表結(jié)構(gòu)的相關(guān)問題,希望對(duì)大家有幫助。

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    推薦學(xué)習(xí):mysql教程

    約束條件

    • 作用是限制如何給字段賦值

    查看約束條件

    • mysql> desc 庫(kù)名.表名;

    mysql> desc db1.t9;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    //如圖所示,每列代表的含義:字段名 | 類型 | 空 | 鍵值 | 默認(rèn)值 | 額外設(shè)置

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

    //如上圖所示,約束條件允許為空(NULL),所以此處賦值的時(shí)候可以為空,null不區(qū)分大小寫

    mysql> select * from  db1.t9;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    mysql> insert into db1.t9(name,sex) values("lucy","girl"); mysql> select * from db1.t9;

    //t9表的約束條件里,第三字段默認(rèn)值為NULL,也就是說當(dāng)沒有給第三字段賦值的時(shí)候,會(huì)以默認(rèn)值填入表中,即如下圖所示默認(rèn)填入NULL

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    設(shè)置約束條件

    • null //允許為空(默認(rèn)設(shè)置)

    • not null //不允許為null(空)

    • key //鍵值類型

    • default //設(shè)置默認(rèn)值,缺省為NULL

    • extra //額外設(shè)置

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

    //創(chuàng)建一個(gè)表db2.t1,name字段的類型為定長(zhǎng)char,約束條件是不允許為空,默認(rèn)值為0個(gè)字符,顯示效果入下圖所示;age字段的類型是微小整數(shù)tinyint,約束條件是不允許為負(fù)數(shù)(unsigned),默認(rèn)值設(shè)置為19,注此處的默認(rèn)值設(shè)置不得超過tinyint類型的范圍,即默認(rèn)值的設(shè)置不能超過255;sex字段的類型為枚舉,enum為單選,約束條件是不允許為空,默認(rèn)值設(shè)置為m;

    mysql> desc db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    mysql> insert into db2.t1(name) values("bob");

    //只給name字段賦值,剩下的字段由默認(rèn)值賦值

    mysql> select * from db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    mysql> insert into db2.t1 values("lucy","21","w");     //給字段賦值,就不會(huì)以默認(rèn)值賦值了 mysql> select * from db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    mysql> insert into db2.t1 values(null,null,null);       //錯(cuò)誤提示,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個(gè)字符,和空不一樣,也可以給字段賦值 mysql> select * from db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    總結(jié)

    約束條件

    類型

    Null(是否允許為空null)

    默認(rèn)允許 null

    不允許為空 not null

    Key(鍵值)

    普通索引 index

    唯一索引 unique

    主鍵 primary key

    外鍵 foreign key

    全文索引 fulltext

    Default(默認(rèn)值:不給字段賦值使用默認(rèn)值賦值)

    默認(rèn)不定義時(shí)是 null

    定義時(shí)是 default(要與字段類型匹配)

    Extra(額外設(shè)置:默認(rèn)都沒有額外設(shè)置)

    修改表結(jié)構(gòu)

    語法結(jié)構(gòu)

    • 用法

    mysql> alter table 庫(kù)名.表名 執(zhí)行動(dòng)作;

    • 執(zhí)行動(dòng)作

    add 添加字段

    modify 修改字段類型

    change 修改字段名

    drop 刪除字段

    rename 修改表名

    添加新字段

    • 用法

    —— 新字段默認(rèn)添加在字段末尾

    mysql> alter table 庫(kù)名.表名 add 字段名 類型(寬度) 約束條件;

    add 字段名 類型 [約束條件] after 字段名;

    add 字段名 類型 [約束條件] first;

    • 不指定位置添加字段

    mysql> alter table db2.t1 add email varchar(50);     //不指定添加字段的位置,默認(rèn)就在末尾 mysql> desc db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

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

    mysql> alter table db2.t1 add hobby set("eat","drink","play","happy") not null default "eat,drink" after age;    //指定添加位置在字段age之后,條件設(shè)置不允許為空,并設(shè)置默認(rèn)值為eat,drink mysql> desc db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    mysql> select * from db2.t1;     //查看表內(nèi)容,發(fā)現(xiàn)hobby字段自動(dòng)添加了默認(rèn)值

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    • 將字段添加到最前面

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

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    mysql> select * from db2.t1; //class字段自動(dòng)添加默認(rèn)值

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    修改字段類型

    • 基本用法

    —— 修改的字段類型不能與已存儲(chǔ)的數(shù)據(jù)沖突

    mysql> alter table 庫(kù)名.表名 modify 字段名 類型(寬度) 約束條件;

    modify 字段名 類型 [約束條件] after 字段名;

    modify 字段名 類型 [約束條件] first;

    注:

    如果表中這個(gè)字段類型下面的字段已經(jīng)有值了,那么修改的類型與約束不能與字段里面已經(jīng)存儲(chǔ)的數(shù)據(jù)發(fā)生沖突,如果發(fā)生沖突則不允許修改。比如,有一個(gè)字段name,里面存儲(chǔ)了一個(gè)數(shù)據(jù)為bob,那么把字段的類型(寬度)改成char(1),則會(huì)修改失敗,因?yàn)閎ob的寬度為3,如果將字段的類型(寬度)改為char(1),則源數(shù)據(jù)bob就存不下了,由于已存儲(chǔ)的數(shù)據(jù)優(yōu)先,所以就不能進(jìn)行修改;

    修改字段的類型時(shí)要注意,不修改的部分要原樣進(jìn)行抄寫,如果不修改的部分不原樣抄寫,那就相當(dāng)于對(duì)其進(jìn)行還原即使用默認(rèn)配置。比如有一個(gè)字段name,他的類型是char(10),約束條件是不允許為空,默認(rèn)值是"",現(xiàn)在要將其類型寬度改為char(20),其余沒修改的部分沒有在命令中進(jìn)行原樣抄寫,那么輸出結(jié)果該字段的約束條件會(huì)變?yōu)槟J(rèn)情況,即允許為空,默認(rèn)值為NULL。改變字段位置的時(shí)候也一樣。

    mysql> desc db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    • 將字段age的位置修改到字段class的后面

    mysql> alter table db2.t1 modify age tinyint unsigned default 19 after class; //除了對(duì)字段age的位置進(jìn)行了修改,其余不修改的地方如:類型(寬度)、約束條件進(jìn)行原樣抄寫

    mysql> desc db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    • 將字段name的類型變?yōu)関archar(15)

    mysql> alter table db2.t1 modify name varchar(15) not null default ""; mysql> desc db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    修改字段名

    • 基本用法

    —— 也可以用來修改字段類型

    mysql> alter table 庫(kù)名.表名 change 源字段名 新字段名 類型(寬度) 約束條件;

    注:也可以用來修改類型和約束條件,只需要寫上新的類型和新的約束條件即可

    mysql> desc db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    • 將字段名email修改為mail

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

    mysql> desc db2.t1;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    • 將字段名mail修改為email,并修改約束條件

    mysql> alter table db2.t1 change mail email varchar(50) not null default "njw@163.com";     //出現(xiàn)錯(cuò)誤,因?yàn)樵磾?shù)據(jù)中,mail字段中的值為NULL,如果將約束條件修改為not null,那么就與源數(shù)據(jù)發(fā)生沖突,所以修改失敗 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知識(shí)點(diǎn)之表結(jié)構(gòu)

    刪除字段

    • 基本用法

    mysql> alter table 庫(kù)名.表名 drop 字段名;

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

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

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

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    修改表名

    • 基本用法

    mysql> alter table 庫(kù)名.表名 rename 新表名;

    庫(kù)名.新表名;

    mysql> use db2;

    mysql> show tables;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

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

    mysql> show tables;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    mysql> select * from stuinfo;

    歸納詳解MySQL知識(shí)點(diǎn)之表結(jié)構(gòu)

    推薦學(xué)習(xí):mysql視頻教程

    贊(0)
    分享到: 更多 (0)
    網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)