MySQL創(chuàng)建和刪除表操作命令實(shí)例講解
創(chuàng)建表
簡單的方式
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創(chuàng)建表:
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 | |
+----------+--------------+-----------------+------+-----+---------+-------+---------------------------------+---------+
創(chuàng)建臨時表:
CREATE TEMPORARY TABLE temp_person (
number INT(11),
name VARCHAR(255),
birthday DATE
);
在創(chuàng)建表格時,您可以使用TEMPORARY關(guān)鍵詞。只有在當(dāng)前連接情況下,TEMPORARY表才是可見的。當(dāng)連接關(guān)閉時,TEMPORARY表被自動取消。這意味著兩個不同的連接可以使用相同的臨時表名稱,同時兩個臨時表不會互相沖突,也不與原有的同名的非臨時表沖突。(原有的表被隱藏,直到臨時表被取消時為止。)您必須擁有CREATE TEMPORARY TABLES權(quán)限,才能創(chuàng)建臨時表。
如果表已存在,則使用關(guān)鍵詞IF NOT EXISTS可以防止發(fā)生錯誤。
CREATE TABLE IF NOT EXISTS person2 (
number INT(11),
name VARCHAR(255),
birthday DATE
);
注意,原有表的結(jié)構(gòu)與CREATE TABLE語句中表示的表的結(jié)構(gòu)是否相同,這一點(diǎn)沒有驗(yàn)證。注釋:如果您在CREATE TABLE...SELECT語句中使用IF NOT EXISTS,則不論表是否已存在,由SELECT部分選擇的記錄都會被插入。
在CREATE TABLE語句的末尾添加一個SELECT語句,在一個表的基礎(chǔ)上創(chuàng)建表
CREATE TABLE new_tbl SELECT * FROM orig_tbl;
注意,用SELECT語句創(chuàng)建的列附在表的右側(cè),而不是覆蓋在表上。
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;
根據(jù)其它表的定義(包括在原表中定義的所有的列屬性和索引),使用LIKE創(chuàng)建一個空表:
CREATE TABLE new_tbl LIKE orig_tbl;
創(chuàng)建一個有主鍵,唯一索引,普通索引的表:
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;
相關(guān)文章
MySQL 數(shù)據(jù)庫優(yōu)化的具體方法說明
以下的文章主要講述的是實(shí)現(xiàn)MySQL數(shù)據(jù)庫簡單實(shí)用優(yōu)化的具體方法,以及在實(shí)際操作中有哪些具體操作步驟是值得我們大家注意的。2010-05-05MySQL 利用frm文件和ibd文件恢復(fù)表數(shù)據(jù)
這篇文章主要介紹了MySQL 利用frm文件和ibd文件恢復(fù)表數(shù)據(jù),幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下2021-03-03k8s搭建mysql集群實(shí)現(xiàn)主從復(fù)制的方法步驟
本文是基于已有k8s環(huán)境下,介紹在k8s環(huán)境中部署mysql主從集群的實(shí)現(xiàn)步驟,對mysql學(xué)習(xí)有一定的幫助,感興趣的可以學(xué)習(xí)一下2023-01-01phpmyadmin出現(xiàn)#2003服務(wù)器無響應(yīng)解決方法小結(jié)
出現(xiàn)登陸phpmyadmin出現(xiàn) #2003 - 服務(wù)器沒有響應(yīng)最先想到的是你的mysql服務(wù)器是不是停止了檢查一下,如果是mysql服務(wù)器停止服務(wù)了重啟就可以解決問題了2012-04-04windows 環(huán)境下 MySQL 8.0.13 免安裝版配置教程
這篇文章主要介紹了windows 環(huán)境下 MySQL 8.0.13 免安裝版配置教程,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧2018-12-12