轉(zhuǎn)帖|行業(yè)資訊|編輯:龔雪|2014-10-29 09:33:11.000|閱讀 311 次
概述:MySQL數(shù)據(jù)庫(kù)常用命令集,包括對(duì)數(shù)據(jù)庫(kù)及其數(shù)據(jù)庫(kù)中的表的處理命令。
# 界面/圖表報(bào)表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
MySQL是世界上最流行的開源數(shù)據(jù)庫(kù)。目前很多人都在使用數(shù)據(jù)庫(kù)管理工具,幫助自己開發(fā)程序。像Navicat和phpadmin都是非常熱門的MySQL數(shù)據(jù)庫(kù)管理工具。當(dāng)作為初學(xué)者,知道必要的MySQL數(shù)據(jù)庫(kù)常用命令是非常重要的,不僅可以更好的理解管理工具的執(zhí)行模式,而且可以大型項(xiàng)目集成中,體現(xiàn)出更佳的操作數(shù)據(jù)庫(kù)優(yōu)勢(shì)。
MySQL數(shù)據(jù)庫(kù)常用命令包括對(duì)數(shù)據(jù)庫(kù)及其數(shù)據(jù)庫(kù)中的表進(jìn)行操作,其中對(duì)表的操作,對(duì)初學(xué)者來(lái)說(shuō)非常關(guān)鍵。
查看數(shù)據(jù)庫(kù)
獲取服務(wù)器上的數(shù)據(jù)庫(kù)列表通常很有用。執(zhí)行show databases;命令就可以搞定。
mysql>show databases;
創(chuàng)建數(shù)據(jù)庫(kù)
mysql>create database db_test;
Query OK, 1 row affected (0.00 sec)
使用數(shù)據(jù)庫(kù)
數(shù)據(jù)庫(kù)一旦創(chuàng)建,就可以通過(guò)“使用”(use命令)數(shù)據(jù)庫(kù),將其指定為默認(rèn)的工作數(shù)據(jù)庫(kù)。
mysql> use db_test;
Database changed
刪除數(shù)據(jù)庫(kù)
刪除數(shù)據(jù)庫(kù)的方式與創(chuàng)建的方式很相似。可以在mysql客戶端中使用drop命令刪除數(shù)據(jù)庫(kù),如下:
mysql> drop database db_test;
Query OK, 0 rows affected (0.00 sec)
這里將對(duì)如何創(chuàng)建、列出、查看、刪除和修改MySQL數(shù)據(jù)庫(kù)表。
創(chuàng)建表
表通過(guò)create table語(yǔ)句來(lái)創(chuàng)建。創(chuàng)建表的過(guò)程中會(huì)使用非常多的選項(xiàng)和子句,在這里完全總結(jié)一遍也是不現(xiàn)實(shí)的,這里只是總結(jié)最普遍的,以后遇到別的,再單個(gè)總結(jié)。創(chuàng)建表的一般用法如下:
mysql> create table tb_test( -> id int unsigned not null auto_increment, -> firstname varchar(25) not null, -> lastname varchar(25) not null, -> email varchar(45) not null, -> phone varchar(10) not null, -> primary key(id));
記住,表至少包含一列。另外,創(chuàng)建表之后總是可以再回過(guò)頭來(lái)修改表的結(jié)構(gòu)。無(wú)論當(dāng)前是否在使用目標(biāo)數(shù)據(jù)庫(kù),都可以創(chuàng)建表,只要在表名前面加上目標(biāo)數(shù)據(jù)庫(kù)即可。例如:
mysql> create table db_test.tb_test( -> id int unsigned not null auto_increment, -> firstname varchar(25) not null, -> lastname varchar(25) not null, -> email varchar(45) not null, -> phone varchar(10) not null, -> primary key(id));
Query OK, 0 rows affected (0.03 sec)
有條件的創(chuàng)建表
在默認(rèn)情況下,如果試圖創(chuàng)建一個(gè)已經(jīng)存在的表,MySQL會(huì)產(chǎn)生一個(gè)錯(cuò)誤。為了避免這個(gè)錯(cuò)誤,create table語(yǔ)句提供了一個(gè)子句,如果你希望在目標(biāo)表已經(jīng)存在的情況下簡(jiǎn)單地退出表創(chuàng)建,就可以使用這個(gè)子句。例如:
mysql> create table if not exists db_test.tb_test( -> id int unsigned not null auto_increment, -> firstname varchar(25) not null, -> lastname varchar(25) not null, -> email varchar(45) not null, -> phone varchar(10) not null, -> primary key(id));
Query OK, 0 rows affected, 1 warning (0.00 sec)
基于現(xiàn)有的表創(chuàng)建新表是一項(xiàng)很容易的任務(wù)。以下代碼將得到tb_test表的一個(gè)副本,名為tb_test2:
mysql> create table tb_test2 select * from db_test.tb_test;
Query OK, 0 rows affected (0.03 sec)
Records: 0 Duplicates: 0 Warnings: 0
將向數(shù)據(jù)庫(kù)增加一個(gè)相同的表tb_test2。而有的時(shí)候,可能希望只基于現(xiàn)有表的幾個(gè)列創(chuàng)建一個(gè)表。通過(guò)create select語(yǔ)句中指定列就可以實(shí)現(xiàn):
mysql> describe tb_test;
+-----------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-----------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| firstname | varchar(25) | NO | | NULL | |
| lastname | varchar(25) | NO | | NULL | |
| email | varchar(45) | NO | | NULL | |
| phone | varchar(10) | NO | | NULL | |
+-----------+------------------+------+-----+---------+----------------+
5 rows in set (0.01 sec)
mysql> create table tb_test2 select id, firstname,lastname, email from tb_test;
Query OK, 0 rows affected (0.03 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> describe tb_test2;
+-----------+------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+------------------+------+-----+---------+-------+
| id | int(10) unsigned | NO | | 0 | |
| firstname | varchar(25) | NO | | NULL | |
| lastname | varchar(25) | NO | | NULL | |
| email | varchar(45) | NO | | NULL | |
+-----------+------------------+------+-----+---------+-------+
4 rows in set (0.01 sec)
創(chuàng)建臨時(shí)表
有的時(shí)候,當(dāng)工作在非常大的表上時(shí),可能偶爾需要運(yùn)行很多查詢獲得一個(gè)大量數(shù)據(jù)的小的子集,不是對(duì)整個(gè)表運(yùn)行這些查詢,而是讓MySQL每次找出所 需的少數(shù)記錄,將記錄保存到一個(gè)臨時(shí)表可能更快一些,然后對(duì)這些臨時(shí)表進(jìn)行查詢操作。可以通過(guò)使用temporary關(guān)鍵字和create table語(yǔ)句來(lái)實(shí)現(xiàn)。
mysql> create temporary table emp_temp select firstname, lastname from tb_test;
Query OK, 0 rows affected (0.02 sec)
Records: 0 Duplicates: 0 Warnings: 0
臨時(shí)表的創(chuàng)建與其它表一樣,只是它們存儲(chǔ)在操作系統(tǒng)指定的臨時(shí)目錄中。臨時(shí)表將在你連接MySQL期間存在,當(dāng)你斷開時(shí),MySQL將自動(dòng)刪除表并釋放所有的內(nèi)存空間;當(dāng)然了,你也可以手動(dòng)的使用drop table命令刪除臨時(shí)表。
查看數(shù)據(jù)庫(kù)中可用的表
可以使用show tables命令完成。例如:
mysql> show tables;
+-------------------+
| Tables_in_db_test |
+-------------------+
| tb_test |
| tb_test2 |
+-------------------+
2 rows in set (0.00 sec)
查看表結(jié)構(gòu)
可以使用describe語(yǔ)句查看表結(jié)構(gòu),例如:
mysql> describe tb_test;
+-----------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-----------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| firstname | varchar(25) | NO | | NULL | |
| lastname | varchar(25) | NO | | NULL | |
| email | varchar(45) | NO | | NULL | |
| phone | varchar(10) | NO | | NULL | |
+-----------+------------------+------+-----+---------+----------------+
5 rows in set (0.00 sec)
另外,使用show命令也能得到相同的結(jié)果,例如:
mysql> show columns in tb_test;
+-----------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-----------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| firstname | varchar(25) | NO | | NULL | |
| lastname | varchar(25) | NO | | NULL | |
| email | varchar(45) | NO | | NULL | |
| phone | varchar(10) | NO | | NULL | |
+-----------+------------------+------+-----+---------+----------------+
5 rows in set (0.00 sec)
刪除表
刪除表是使用drop table語(yǔ)句實(shí)現(xiàn)的,其語(yǔ)法如下:
drop [temporary] table [if exists] tbl_name [, tbl_name, ...]
更改表結(jié)構(gòu)
我們會(huì)發(fā)現(xiàn),我們會(huì)經(jīng)常修改和改進(jìn)表結(jié)構(gòu),特別是在開發(fā)初期;但是,每次進(jìn)行修改時(shí)不必都先刪除再重新創(chuàng)建表。相反,可以使用alter語(yǔ)句修改表 的結(jié)構(gòu)。利用這個(gè)語(yǔ)句,可以再必要時(shí)刪除、修改和增加列。和create table一樣,alter table提供了很多子句、關(guān)鍵字和選項(xiàng)。這里只是會(huì)說(shuō)一些簡(jiǎn)單的使用,比如在表tb_demo表中插入一列,表示email,代碼如下:
mysql> alter table tb_demo add column email varchar(45);
Query OK, 0 rows affected (0.14 sec)
Records: 0 Duplicates: 0 Warnings: 0
新的列放在表的最后位置。不過(guò),還可以使用適當(dāng)?shù)年P(guān)鍵字(包括first、after和last)來(lái)控制新列的位置。如果想修改表,比如,剛剛加的email,我想加入一個(gè)not null控制,代碼可以是這樣的:
mysql> alter table tb_demo change email email varchar(45) not null;
Query OK, 0 rows affected (0.11 sec)
Records: 0 Duplicates: 0 Warnings: 0
如果覺(jué)的這個(gè)email這列沒(méi)有存在的必要了,可以使用下面的代碼刪除它,例如:
mysql> alter table tb_demo drop email;
Query OK, 0 rows affected (0.09 sec)
Records: 0 Duplicates: 0 Warnings: 0
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請(qǐng)務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請(qǐng)郵件反饋至chenjj@fc6vip.cn