mysql建立表_mysql快速建表的方法

mysql快速建表的语句写法并不复杂,下面就为您详细介绍两种最常用的mysql快速建表的语句:

1:create table t_select select * from t_old where1=0;

2:create table t_select1 like t_old;

但是***种mysql快速建表的语句有缺陷,他能取消原来表的有些定义。(手册上说Some conversion of data types might occur. For example, the AUTO_INCREMENT attribute is not preserved, and VARCHAR columns can become CHAR columns. )

可以看看下面的例子

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

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=InnoDBDEFAULTCHARSET=utf8

create table t_select select * from t_old where1=0;

CREATE TABLE `t_select` (

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

`content` varchar(8000) NOT NULL,

`desc` varchar(100) NOT NULL

)ENGINE=MyISAMDEFAULTCHARSET=utf8

这样 自增字段跟表引擎都变了

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

如:

create table t_select engine innodb select * from t_old where1=0; create table t_like like t_old;

show CREATE table t_like;

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=InnoDBDEFAULTCHARSET=utf8

这样引擎跟自增字段都没有变

看下面一个一个例子,就知道有什么变化了

CREATE TABLE `t4_innodb` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`a1` int(11) NOT NULL,

`a2` int(11) DEFAULT NULL,

`remark` varchar(200) NOT NULL,

PRIMARY KEY (`id`),

KEY `a1_2_idx` (`a1`)

)ENGINE=InnoDBDEFAULTCHARSET=utf8

create table t6_innodb select * from t4_innodb where1=2;

CREATE TABLE `t6_innodb` (

`id` int(11) NOT NULL DEFAULT '0',

`a1` int(11) NOT NULL,

`a2` int(11) DEFAULT NULL,

`remark` varchar(200) NOT NULL

)ENGINE=InnoDBDEFAULTCHARSET=utf8

create table t8_innodb like t4_innodb;

CREATE TABLE `t8_innodb` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`a1` int(11) NOT NULL,

`a2` int(11) DEFAULT NULL,

`remark` varchar(200) NOT NULL,

PRIMARY KEY (`id`),

KEY `a1_2_idx` (`a1`)

)ENGINE=InnoDBDEFAULTCHARSET=utf8

【编辑推荐】

【责任编辑:段燃 TEL:(010)68476606】

点赞 0

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值