好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

mysql创建和删除表

创建表 简单的方式 CREATE TABLE person (number INT( 11 ),name VARCHAR( 255 ),birthday DATE); 或者是 CREATE TABLE IF NOT EXISTS person (number INT( 11 ),name VARCHAR( 255 ),birthday DATE); 查看mysql创建表: SHOW CREATE table person; CREATE TA

创建表

简单的方式

 CREATE TABLE person (
number INT(  11  ),
name VARCHAR(  255  ),
birthday DATE
);  

或者是

 CREATE TABLE IF NOT EXISTS person (
number INT(  11  ),
name VARCHAR(  255  ),
birthday DATE
);  

查看mysql创建表:

 SHOW CREATE table person;

  CREATE TABLE `person` (
  `number`   int ( 11  ) DEFAULT NULL,
  `name` varchar(  255  ) DEFAULT NULL,
  `birthday`   date   DEFAULT NULL
) ENGINE =MyISAM DEFAULT CHARSET=utf8; 

查看表所有的列:

 SHOW FULL COLUMNS from person;
 +----------+--------------+-----------------+------+-----+---------+-------+---------------------------------+---------+
| Field    | Type         | Collation       | Null | Key | Default | Extra | Privileges                      | Comment |
+----------+--------------+-----------------+------+-----+---------+-------+---------------------------------+---------+
| number   |  int ( 11 )      | NULL            | YES  |     | NULL    |       |  select ,insert,update,references |         |
| name     | varchar( 255 ) | utf8_general_ci | YES  |     | NULL    |       |  select ,insert,update,references |         |
| birthday |  date          | NULL            | YES  |     | NULL    |       |  select ,insert,update,references |         |
+----------+--------------+-----------------+------+-----+---------+-------+---------------------------------+---------+ 

创建临时表

 CREATE TEMPORARY TABLE temp_person (
number INT(  11  ),
name VARCHAR(  255  ),
birthday DATE
);  

在创建表格时,您可以使用 TEMPORARY 关键词。只有在当前连接情况下, TEMPORARY 表才是可见的。当连接关闭时, TEMPORARY 表被自动取消。这意味着两个不同的连接可以使用相同的临时表名称,同时两个临时表不会互相冲突,也不与原有的同名的非临时表冲突。(原有的表被隐藏,直到临时表被取消时为止。)您必须拥有 CREATE TEMPORARY TABLES 权限,才能创建临时表。

如果表已存在,则使用关键词 IF NOT EXISTS 可以防止发生错误。

 CREATE TABLE IF NOT EXISTS person2 (
number INT(  11  ),
name VARCHAR(  255  ),
birthday DATE
);  

注意,原有表的结构与 CREATE TABLE 语句中表示的表的结构是否相同,这一点没有验证。注释:如果您在 CREATE TABLE...SELECT 语句中使用 IF NOT EXISTS ,则不论表是否已存在,由 SELECT 部分选择的记录都会被插入。

在 CREATE TABLE 语句的末尾添加一个 SELECT 语句,在一个表的基础上创建表

CREATE TABLE new_tbl SELECT * FROM orig_tbl; 

注意,用 SELECT 语句创建的列附在表的右侧,而不是覆盖在表上

mysql> SELECT *  FROM foo;
 +---+
| n |
+---+
|  1  |
+---+ 
mysql >  CREATE TABLE bar (m INT) SELECT n FROM foo;
mysql > SELECT *  FROM bar;
 +------+---+
| m    | n |
+------+---+
| NULL |  1  |
+------+---+ 

也可以明确地为一个已生成的列指定类型

CREATE TABLE foo (a TINYINT NOT NULL) SELECT b+ 1  AS a FROM bar; 

根据其它表的定义(包括在原表中定义的所有的列属性和索引),使用 LIKE 创建一个空表 :

CREATE TABLE new_tbl LIKE orig_tbl; 

创建一个有主键,唯一索引,普通索引的表:

 CREATE TABLE `people` (
  `peopleid` smallint(  6  ) NOT NULL AUTO_INCREMENT,
  `firstname`   char ( 50  ) NOT NULL,
  `lastname`   char ( 50  ) NOT NULL,
  `age` smallint(  6  ) NOT NULL,
  `townid` smallint(  6  ) NOT NULL,
  PRIMARY KEY (`peopleid`),
  UNIQUE KEY `unique_fname_lname`(`firstname`,`lastname`),
  KEY `fname_lname_age` (`firstname`,`lastname`,`age`)
) ;  

其中peopleid是主键,以firstname和lastname两列建立了一个唯一索引,以firstname,lastname,age三列建立了一个普通索引

删除表

DROP TABLE  tbl_name; 

或者是

DROP TABLE IF EXISTS tbl_name; 

查看更多关于mysql创建和删除表的详细内容...

  阅读:33次