標籤:覆蓋 衝突 extra har type 建表 類型 isa exists
建立表簡單的方式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建立和刪除