應(yīng)該使用英文半角的分號(hào)來(lái)作為一條MySQL命令或者語(yǔ)句的結(jié)束符。
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供崇義網(wǎng)站建設(shè)、崇義做網(wǎng)站、崇義網(wǎng)站設(shè)計(jì)、崇義網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、崇義企業(yè)網(wǎng)站模板建站服務(wù),十余年崇義做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
使用: mysql -u root -p 進(jìn)入 mysql 命令號(hào)以后, 如果想退出, 可以使用: quit 命令, 如下:
mysql -u root -p
quit;
擴(kuò)展資料:
數(shù)據(jù)庫(kù)常用操作:
登錄到mysql中,然后在mysql的提示符下運(yùn)行下列命令,每個(gè)命令以分號(hào)結(jié)束。
1、顯示數(shù)據(jù)庫(kù)列表。
show databases;
缺省有兩個(gè)數(shù)據(jù)庫(kù):mysql和test。 mysql庫(kù)存放著mysql的系統(tǒng)和用戶權(quán)限信息,我們改密碼和新增用戶,實(shí)際上就是對(duì)這個(gè)庫(kù)進(jìn)行操作。
2、 顯示庫(kù)中的數(shù)據(jù)表:
use mysql;
show tables;
3、 顯示數(shù)據(jù)表的結(jié)構(gòu):describe 表名;
4、 建庫(kù)與刪庫(kù):
create database 庫(kù)名;
drop database 庫(kù)名;
5、 建表:
use 庫(kù)名;
create table 表名(字段列表);
drop table 表名;
6、 清空表中記錄:
delete from 表名;
truncate table 表名;
7、 顯示表中的記錄:select * from 表名;
? create procedure用來(lái)創(chuàng)建 存儲(chǔ)過(guò)程 ,create function用來(lái)創(chuàng)建 函數(shù)
? Delimiter命令是改變語(yǔ)句的結(jié)束符 ,MySQL默認(rèn)的結(jié)束符為;號(hào),由于procedure和function中的;號(hào)并不代表創(chuàng)建的結(jié)束,所以要替換成另外的結(jié)束符以便表示創(chuàng)建的結(jié)束
? rontine_body子句可以包含一個(gè)簡(jiǎn)單的SQL語(yǔ)句,也可以包含多個(gè)SQL語(yǔ)句, 通過(guò)begin…end將這多個(gè)SQL語(yǔ)句 包含在一起
? MySQL存儲(chǔ)過(guò)程和函數(shù)中也可以包含類似create和drop等DDL語(yǔ)句
? comment子句用來(lái)寫(xiě)入對(duì)存儲(chǔ)過(guò)程和函數(shù)的注釋
? Language子句用來(lái)表示此存儲(chǔ)過(guò)程和函數(shù)的創(chuàng)建語(yǔ)言
? 存儲(chǔ)過(guò)程和函數(shù)被標(biāo)注為deterministic表明當(dāng)輸入相同的參數(shù)是會(huì)返回相同的結(jié)果,反之如果是not deterministic則表示相同參數(shù)不會(huì)是相同結(jié)果,默認(rèn)是not deterministic
? 相關(guān)屬性短語(yǔ)只有咨詢含義,并不是強(qiáng)制性的約束
? Drop procedure/function語(yǔ)句用來(lái) 刪除指定名稱的存儲(chǔ)過(guò)程或函數(shù)
? Begin…end語(yǔ)句通常出現(xiàn)在存儲(chǔ)過(guò)程、函數(shù)和觸發(fā)器中,其中 可以包含一個(gè)或多個(gè)語(yǔ)句 ,每個(gè)語(yǔ)句用;號(hào)隔開(kāi)
? 標(biāo)簽label可以加在begin…end語(yǔ)句以及l(fā)oop, repeat和while語(yǔ)句
? 語(yǔ)句中通過(guò)iterate和leave來(lái)控制流程,iterate表示返回指定標(biāo)簽位置,leave表示跳出標(biāo)簽
? Declare語(yǔ)句通常用來(lái)聲明本地變量、游標(biāo)、條件或者h(yuǎn)andler
? Declare語(yǔ)句只允許出現(xiàn)在begin … end語(yǔ)句中而且必須出現(xiàn)在第一行
? Declare的順序也有要求,通常是先聲明本地變量,再是游標(biāo),然后是條件和handler
? 本地變量可以通過(guò)declare語(yǔ)句進(jìn)行聲明
? 聲明后的變量可以通過(guò)select … into var_list進(jìn)行賦值,或者通過(guò)set語(yǔ)句賦值,或者通過(guò)定義游標(biāo)并使用fetch … into var_list賦值
? 通過(guò)declare聲明變量方法:
? MySQL支持if,case,iterate,leave,loop,while,repeat語(yǔ)句作為存儲(chǔ)過(guò)程和函數(shù)中的 流程控制語(yǔ)句 ,另外return語(yǔ)句也是函數(shù)中的特定流程控制語(yǔ)句
? Case語(yǔ)句在存儲(chǔ)過(guò)程或函數(shù)中表明了 復(fù)雜的條件選擇語(yǔ)句
? IF語(yǔ)句在存儲(chǔ)過(guò)程或函數(shù)中表明了 基礎(chǔ)的條件選擇語(yǔ)句
其中在 function 里面,只有 DETERMINISTIC, NO SQL 和 READS SQL DATA 被支持。如果我們開(kāi)啟了 bin-log, 我們就必須為我們的 function 指定一個(gè)參數(shù)。
在 MySQL 中創(chuàng)建函數(shù)時(shí)出現(xiàn)這種錯(cuò)誤的解決方法:
set global log_bin_trust_function_creators=TRUE;
? Iterate語(yǔ)句 僅出現(xiàn)在loop,repeat,while循環(huán)語(yǔ)句中,其含義表示重新開(kāi)始此循環(huán)
? Leave語(yǔ)句表明 退出指定標(biāo)簽的流程控制語(yǔ)句塊
? 通常會(huì)用在begin…end,以及l(fā)oop,repeat,while的循環(huán)語(yǔ)句中
? Loop語(yǔ)句是存儲(chǔ)過(guò)程或函數(shù)中表達(dá) 循環(huán)執(zhí)行 的一種方式
? repeat語(yǔ)句是存儲(chǔ)過(guò)程或函數(shù)中表達(dá) 循環(huán)執(zhí)行 的一種方式
? while語(yǔ)句是存儲(chǔ)過(guò)程或函數(shù)中表達(dá) 循環(huán)執(zhí)行 的一種方式
? Return語(yǔ)句用在 函數(shù)中,用來(lái)終結(jié)函數(shù)的執(zhí)行并將指定值返回給調(diào)用者
? Cursor游標(biāo)用來(lái) 聲明一個(gè)數(shù)據(jù)集
? 游標(biāo)的聲明必須在變量和條件聲明之后,在handler聲明之前
? Cursor close語(yǔ)句用來(lái) 關(guān)閉之前打開(kāi)的游標(biāo)
? Cursor declare語(yǔ)句用來(lái)聲明一個(gè)游標(biāo)和指定游標(biāo)對(duì)應(yīng)的數(shù)據(jù)集合, 通常數(shù)據(jù)集合是一個(gè)select語(yǔ)句
? Cursor fetch語(yǔ)句用來(lái)獲取游標(biāo)指定數(shù)據(jù)集的 下一行數(shù)據(jù) 并將各個(gè)字段值賦予后面的變量
? Open cursor語(yǔ)句用來(lái)打開(kāi)一個(gè)之前已經(jīng) 聲明好的游標(biāo)
? Declare condition語(yǔ)句命名 特定的錯(cuò)誤條件 ,而該特定錯(cuò)誤可以在declare…h(huán)andler中指定 處理方法
? 比如在MySQL中1051error code表示的是unknown table的錯(cuò)誤,如果要對(duì)這
個(gè)錯(cuò)誤做特殊處理,可以用三種方法:
? Declare handler語(yǔ)句用來(lái)聲明一個(gè)handler來(lái)處理一個(gè)或多個(gè)特殊條件,當(dāng)其中的某個(gè)條件滿足時(shí)則觸發(fā)其中的statement語(yǔ)句執(zhí)行
? Statement可以是一個(gè)簡(jiǎn)單SQL語(yǔ)句,也可以是begin…end組成的多個(gè)語(yǔ)句
? Handler_action子句聲明當(dāng)執(zhí)行完statement語(yǔ)句之后應(yīng)該怎么辦
Condition_value的值有以下幾種:
? 當(dāng)condition發(fā)生但沒(méi)有聲明handler時(shí),則存儲(chǔ)過(guò)程和函數(shù)依照如下規(guī)則處理
? create trigger語(yǔ)句用來(lái)創(chuàng)建一個(gè)觸發(fā)器,觸發(fā)器的作用是當(dāng)表上有對(duì)應(yīng)SQL語(yǔ)句發(fā)生時(shí),則觸發(fā)執(zhí)行
? 觸發(fā)器創(chuàng)建時(shí)需要 指定對(duì)應(yīng)的表名 tbl_name
? Definer關(guān)鍵詞用來(lái)指定trigger的安全環(huán)境
? Trigger_time指定觸發(fā)器的執(zhí)行時(shí)間,BEFORE和AFTER指定觸發(fā)器在表中的 每行數(shù)據(jù)修改前或者后 執(zhí)行
? Trigger_event指定觸發(fā)該觸發(fā)器的具體 事件
? INSERT當(dāng)新的一行數(shù)據(jù)插入表中時(shí)觸發(fā),比如通過(guò)執(zhí)行insert,load data,replace語(yǔ)句插入新數(shù)據(jù)
? UPDATE當(dāng)表的一行數(shù)據(jù)被修改時(shí)觸發(fā),比如執(zhí)行update語(yǔ)句時(shí)
? DELETE當(dāng)表的一行數(shù)據(jù)被刪除時(shí)觸發(fā),比如執(zhí)行delete,replace語(yǔ)句時(shí)
? 當(dāng)執(zhí)行insert into … on duplicate key update語(yǔ)句時(shí),當(dāng)碰到重復(fù)行執(zhí)行update時(shí),則觸發(fā)update下的觸發(fā)器
? 從5.7.2版本開(kāi)始,可以創(chuàng)建具有相同trigger_time和trigger_event的同一個(gè)表上的多個(gè)觸發(fā)器,默認(rèn)情況下按照創(chuàng)建的時(shí)間依次執(zhí)行,通過(guò) 指定FOLLOWS/PRECEDES改變執(zhí)行順序 ,即FOLLOWS時(shí)表示新創(chuàng)建的觸發(fā)器后執(zhí)行,PRECEDES則表示新觸發(fā)器先執(zhí)行
? Trigger_body表示觸發(fā)器觸發(fā)之后要執(zhí)行的一個(gè)或多個(gè)語(yǔ)句,在內(nèi)部可以引用涉及表的字段, OLD.col_name表示行數(shù)據(jù)被修改或刪除之前的字段數(shù)據(jù),NEW.col_name表示行數(shù)據(jù)被插入或修改之后的字段數(shù)據(jù)
? Drop trigger語(yǔ)句用來(lái) 刪除一個(gè)觸發(fā)器
? If exists短語(yǔ)用來(lái)避免刪除不存在的觸發(fā)器時(shí)引發(fā)報(bào)錯(cuò)
? 當(dāng)你執(zhí)行drop table時(shí),表上的觸發(fā)器也被drop掉了
kill掉 ~
show processlist;
找出你要停止的語(yǔ)句
然后找出你要終止的語(yǔ)句的id
在系統(tǒng)下mysqladmin -uroot -ppassword kill 要?dú)⒌腎D
進(jìn)入mysql命令行之后可以按鍵ctrl+c來(lái)退出mysql命令客戶端;
也可以在命令行輸入quit按回車(chē)鍵來(lái)退出命令行。
擴(kuò)展資料
mysql命令行常用命令使用方法介紹:
1、連接和斷開(kāi)服務(wù)器
shell mysql -h host -u user -p
Enter password: ********
host和user分別代表MySQL服務(wù)器運(yùn)行的主機(jī)名和MySQL賬戶用戶名。設(shè)置時(shí)替換為正確的值。********?代表你的密碼;當(dāng)mysql顯示Enter password:提示時(shí)輸入它。
2、mysql的-e或--execute選項(xiàng)
對(duì)mysql偶爾有用的另一個(gè)選項(xiàng)是-e或--execute選項(xiàng),可用來(lái)將SQL語(yǔ)句傳遞給服務(wù)器。該語(yǔ)句必須用引號(hào)引起來(lái)(單引號(hào)或雙引號(hào))。(然而,如果想要在查詢中將值引起來(lái),則對(duì)于查詢應(yīng)使用雙引號(hào),查詢中引用的值應(yīng)使用單引號(hào))。
當(dāng)使用該選項(xiàng)時(shí),語(yǔ)句被執(zhí)行,然后mysql立即退出命令外殼。
例如,你可以用下面的命令獲得用戶賬戶列表:
shell mysql -u root -p -e "SELECT User, Host FROM User" mysql
3、從文本文件執(zhí)行SQL語(yǔ)句
要想實(shí)現(xiàn),創(chuàng)建一個(gè)文本文件text_file,并包含你想要執(zhí)行的語(yǔ)句。然后按如下所示調(diào)用mysql:
shell mysql db_name text_file
操作步驟:
show processlist;
找出你要停止的語(yǔ)句
然后找出你要終止的語(yǔ)句的id
在系統(tǒng)下mysqladmin -uroot -ppassword kill 要?dú)⒌腎D
MySQL查詢語(yǔ)句執(zhí)行的過(guò)程:
客戶端發(fā)送一條查詢給服務(wù)器;
服務(wù)器先會(huì)檢查查詢緩存,如果命中了緩存,則立即返回存儲(chǔ)在緩存中的結(jié)果。否則進(jìn)入下一階段;
服務(wù)器端進(jìn)行SQL解析、預(yù)處理,再由優(yōu)化器生成對(duì)應(yīng)的執(zhí)行計(jì)劃;
MySQL根據(jù)優(yōu)化器生成的執(zhí)行計(jì)劃,調(diào)用存儲(chǔ)引擎的API來(lái)執(zhí)行查詢;
將結(jié)果返回給客戶端。