mysql表怎么删除

发布网友

我来回答

3个回答

懂视网

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;

 

关于索引更多可以参考:http://www.cnblogs.com/ggjucheng/archive/2012/11/04/2754128.html

mysql创建/删除表的例子

标签:

热心网友

MySQL 删除数据表

MySQL中删除数据表是非常容易操作的, 但是你再进行删除表操作时要非常小心,因为执行删除命令后所有数据都会消失。

本回答来自:MySQL 删除数据表_树懒学堂

语法

以下为删除MySQL数据表的通用语法:

在命令提示窗口中删除数据表

在mysql>命令提示窗口中删除数据表SQL语句为 DROP TABLE :

实例

以下实例删除了数据表shulanxt_tbl:

热心网友

1 找个别的机器安装个同版本的mysql或从已安装同版本的其他机器上(非同版本的也可以试下):拷贝 mysql/data/mysql 目录到你的mysql/data/ 下吧2 试着启动mysql服务,如果能启动了,理论上应该丢失的只有用户、授权等一些系统信息,不影响你的使用的数据;如果不能启动,看错误日志,争取启动了。3 赶紧把数据备份一份出来,重新把所有库(只是你后来创建的业务相关的库,不包括mysql库)都删了,重新导入一遍。理论上不这样也可以,但只是非生产重要的环境下。4 重新做用户授权。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com