1. 程式人生 > >mysql創建和刪除

mysql創建和刪除

ima myisam 索引 default utf8 field 可見 不同 def

創建表

簡單的方式

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創建和刪除