亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

在MYSQL中快速創建空表

標簽:
MySQL


今天有人问我用什么方法可以创建空表?

在MYSQL中有两种方法。

1、create table select ...

2、create table like ...

第一种很多人都知道,第二种却很少人用。

第一种有个缺点:

取消掉原来表的有些定义。

手册上是这么讲的:

Some conversion of data types might occur. For example, the AUTO_INCREMENT attribute is not preserved, and VARCHAR columns can become CHAR columns. 

不过我测试过,只会取消自增属性!(可能是版本不同吧。其他版本没有测试过!)

第二种就不会。

我们来看看例子:

mysql> create table t_old (id serial, content varchar(8000) not null,`desc` varchar(100) not null) engine innodb;

Query OK, 0 rows affected (0.01 sec)

mysql> show create table t_old;

+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+

| Table | Create Table                                                                                                                                                                                                 |

+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+

| t_old | CREATE TABLE `t_old` (

  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,

  `content` varchar(8000) NOT NULL,

  `desc` varchar(100) NOT NULL,

  UNIQUE KEY `id` (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 | 

+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+

1 row in set (0.00 sec)

mysql> create table t_select select * from t_old where 1 = 0;

Query OK, 0 rows affected (0.01 sec)

Records: 0  Duplicates: 0  Warnings: 0

PS:如果想要保持一样的引擎,就加上。

这样写:create table t_select engine innodb select * from t_old where 1 = 0;

mysql> show create table t_select;

+----------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+

| Table    | Create Table                                                                                                                                                                       |

+----------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+

| t_select | CREATE TABLE `t_select` (

  `id` bigint(20) unsigned NOT NULL DEFAULT '0',

  `content` varchar(8000) NOT NULL,

  `desc` varchar(100) NOT NULL

) ENGINE=MyISAM DEFAULT CHARSET=utf8 | 

+----------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+

1 row in set (0.00 sec)

mysql> create table t_like like t_old;

Query OK, 0 rows affected (0.02 sec)

mysql> show create table t_like;

+--------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+

| Table  | Create Table                                                                                                                                                                                                  |

+--------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+

| t_like | CREATE TABLE `t_like` (

  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,

  `content` varchar(8000) NOT NULL,

  `desc` varchar(100) NOT NULL,

  UNIQUE KEY `id` (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 | 

+--------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+

1 row in set (0.00 sec)

©著作权归作者所有:来自51CTO博客作者david_yeung的原创作品,如需转载,请与作者联系,否则将追究法律责任

MYSQL数据库创建SQL语句与特殊技巧


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消