主要從事網(wǎng)頁(yè)設(shè)計(jì)、PC網(wǎng)站建設(shè)(電腦版網(wǎng)站建設(shè))、wap網(wǎng)站建設(shè)(手機(jī)版網(wǎng)站建設(shè))、響應(yīng)式網(wǎng)站、程序開(kāi)發(fā)、微網(wǎng)站、小程序定制開(kāi)發(fā)等,憑借多年來(lái)在互聯(lián)網(wǎng)的打拼,我們?cè)诨ヂ?lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)積累了豐富的網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì)、網(wǎng)絡(luò)營(yíng)銷經(jīng)驗(yàn),集策劃、開(kāi)發(fā)、設(shè)計(jì)、營(yíng)銷、管理等多方位專業(yè)化運(yùn)作于一體,具備承接不同規(guī)模與類型的建設(shè)項(xiàng)目的能力。
有時(shí)候我們需要原封不動(dòng)的復(fù)制一張表的表結(jié)構(gòu)來(lái)生成一張新表,MySQL提供了兩種便捷的方法。
例:
CREATE TABLE tb_base( id INT NOT NULL PRIMARY KEY, name VARCHAR(10), KEY ix_name (name)) ENGINE='MyISAM',CHARSET=utf8,COMMENT 'a' ;
insert into tb_base() values(1,'a'),(2,'b');
一、LIKE方法
like方法能一模一樣的將一個(gè)表的結(jié)果復(fù)制生成一個(gè)新表,包括復(fù)制表的備注、索引、主鍵外鍵、存儲(chǔ)引擎等。
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name { LIKE old_tbl_name | (LIKE old_tbl_name) }
1.復(fù)制表
CREATE TABLE IF NOT EXISTS tb_base_like (LIKE tb_base);
2.查看表
可以看到新復(fù)制的表和原表完全一致。
二、SELECT方法
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name SELECT ... (Some valid select or union statement)
1.復(fù)制表
CREATE TABLE IF NOT EXISTS tb_base_select SELECT * FROM tb_base;
2.查看表
like的方法值復(fù)制字段屬性,其它的主鍵、索引、表備注、存儲(chǔ)引擎都沒(méi)有復(fù)制
三、區(qū)別
like方法:like方法其實(shí)是專門復(fù)制表結(jié)構(gòu)的方法,但是它只復(fù)制表的結(jié)構(gòu)和相關(guān)屬性并不復(fù)制數(shù)據(jù)
select方法:嚴(yán)格來(lái)講select方法不能理解成復(fù)制表結(jié)構(gòu)的方法,其實(shí)它只是執(zhí)行了一個(gè)select查詢語(yǔ)句,所以復(fù)制的結(jié)果只包含了select的字段和數(shù)據(jù),其它表屬性都有系統(tǒng)的配置文件決定;包括存儲(chǔ)引擎、默認(rèn)字符集等都是有系統(tǒng)的默認(rèn)配置所決定。
所以真正的表結(jié)構(gòu)復(fù)制方法是LIKE方法,如果不需要考慮表原本的屬性包括存儲(chǔ)引擎、備注、主鍵、索引等那么select復(fù)制方法是個(gè)不錯(cuò)的方法并且還能連同數(shù)據(jù)一起復(fù)制。
有時(shí)候我們需要原封不動(dòng)的復(fù)制一張表的表結(jié)構(gòu)來(lái)生成一張新表,MYSQL提供了兩種便捷的方法。
例:
CREATE TABLE tb_base( id INT NOT NULL PRIMARY KEY, name VARCHAR(10),KEY ix_name (name)) ENGINE='MyISAM',CHARSET=utf8,COMMENT 'a' ;
insert into tb_base() values(1,'a'),(2,'b');
一、LIKE方法
like方法能一模一樣的將一個(gè)表的結(jié)果復(fù)制生成一個(gè)新表,包括復(fù)制表的備注、索引、主鍵外鍵、存儲(chǔ)引擎等。
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name { LIKE old_tbl_name | (LIKE old_tbl_name) }
1.復(fù)制表
CREATE TABLE IF NOT EXISTS tb_base_like (LIKE tb_base);
2.查看表
可以看到新復(fù)制的表和原表完全一致。
二、SELECT方法
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_nameSELECT ... (Some valid select or union statement)
1.復(fù)制表
CREATE TABLE IF NOT EXISTS tb_base_select SELECT * FROM tb_base;
2.查看表
like的方法值復(fù)制字段屬性,其它的主鍵、索引、表備注、存儲(chǔ)引擎都沒(méi)有復(fù)制
三、區(qū)別
like方法:like方法其實(shí)是專門復(fù)制表結(jié)構(gòu)的方法,但是它只復(fù)制表的結(jié)構(gòu)和相關(guān)屬性并不復(fù)制數(shù)據(jù)
select方法:嚴(yán)格來(lái)講select方法不能理解成復(fù)制表結(jié)構(gòu)的方法,其實(shí)它只是執(zhí)行了一個(gè)select查詢語(yǔ)句,所以復(fù)制的結(jié)果只包含了select的字段和數(shù)據(jù),其它表屬性都有系統(tǒng)的配置文件決定;包括存儲(chǔ)引擎、默認(rèn)字符集等都是有系統(tǒng)的默認(rèn)配置所決定。
所以真正的表結(jié)構(gòu)復(fù)制方法是LIKE方法,如果不需要考慮表原本的屬性包括存儲(chǔ)引擎、備注、主鍵、索引等那么select復(fù)制方法是個(gè)不錯(cuò)的方法并且還能連同數(shù)據(jù)一起復(fù)制。