導航:首頁 > 程序命令 > sql命令執行後執行

sql命令執行後執行

發布時間:2022-11-30 00:21:58

㈠ oracle中在sql plus中寫完sql語句後按什麼鍵執行

oracle
sqlplus
執行sql命令為:
以命令行方式運行SQL命令,只需要在輸入完SQL語句之後,輸入分號(;),或者在新的一行輸入前斜線(/),按回車鍵即可
SQL>
SELECT
ename,sal
FROM
emp

㈡ sql查詢語句的各個命令執行的標准順序是什麼為什麼

查詢語句是sql語句中使用最多的操作,也涉及到非常多的命令。比如where過濾,group

by分組,order by 排序 limit取值 having等。雖然多,但是各個命令執行的時候卻是有順序的,順序如下:
select *
from 表名
①-- where 條件1
②-- group by 依據列
③-- having 條件2
④-- order by 依據列
⑤-- limit 0,1

為什麼是這么個順序,原因:
limit取值永遠是最後一個.
如果你要order by排序,前提是要首先得到一個查詢結果.
查詢結果中的三個關鍵詞,where總是是放在表名的後面,而havin過濾永遠是放在group後面,所以就有了這么個順序.如果不遵循順序,就會出現錯誤。

是不是這樣,我們可以用下面的建表語句驗證下.
drop table if exists students;
create table students (
studentNo varchar(10) primary key,
name varchar(10),
sex varchar(1),
hometown varchar(20),
age tinyint(4),
class varchar(10),
card varchar(20)
);
insert into students values
('001', '王昭君', '女', '北京', '20', '1班', '340322199001247654'),
('002', '諸葛亮', '男', '上海', '18', '2班', '340322199002242354'),
('003', '張飛', '男', '南京', '24', '3班', '340322199003247654'),
('004', '白起', '男', '安徽', '22', '4班', '340322199005247654'),
('005', '大喬', '女', '天津', '19', '3班', '340322199004247654'),
('006', '孫尚香', '女', '河北', '18', '1班', '340322199006247654'),
('007', '百里玄策', '男', '山西', '20', '2班', '340322199007247654'),
('008', '小喬', '女', '河南', '15', '3班', null),
('009', '百里守約', '男', '湖南', '21', '1班', ''),
('010', '妲己', '女', '廣東', '26', '2班', '340322199607247654'),
('011', '李白', '男', '北京', '30', '4班', '340322199005267754'),
('012', '孫臏', '男', '新疆', '26', '3班', '340322199000297655')

查詢該表中除1班外,所有其他班級的最大年齡,最小年齡,並且按照班號進行降序排列(過濾掉2班,只顯示最前面的一條信息)

那麼sql語句就是: select class,max(age),min(age) from students where class !='1班' group by class having class !='2班' order by class desc limit 1

在這條語句中,新人非常容易犯的錯誤 就是根據題意,將having放在order by 後面導致錯誤。原因在於order by應該放在hving的後面。 還有其他疑問的話建議你去搜一下黑馬程序員,在IT業內算是比較有實力的機構,裡面有線上和線下的課程,還有免費的視頻,每天看一點學一下還是比較有用的。不過,如果真的是想入行或者進階的話,花一段時間高專注度的學習是非常有必要的,投資自己報課試一下吧。

㈢ 對於已經執行成功的sql命令,如何回滾

當啟動Binlog後,事務會產生Binlog Event,這些Event被看做事務數據的一部分。因此要保證事務的Binlog Event和InnoDB引擎中的數據的一致性。所以帶Binlog的CrashSafe要求MySQL宕機重啟後能夠保證:

- 所有已經提交的事務的數據仍然存在。

- 所有沒有提交的事務的數據自動回滾。

- 所有已經提交了的事務的Binlog Event也仍然存在。

- 所有沒有提交事務沒有記錄Binlog Event。

這些要求很好理解,如果重啟後數據還在,但是Binlog Event沒有了,就沒辦法復制到其他節點上了。如果重啟後,數據沒了,但是Binlog Event還在,那麼不存在的數據就會被復制到其他節點上,從而導致主從的不一致。

為了保證帶Binlog的CrashSafe,MySQL內部使用的兩階段提交(Two Phase Commit)。

2 - MySQL的Two Phase Commit(2PC)

在開啟Binlog後,MySQL內部會自動將普通事務當做一個XA事務來處理:
- 自動為每個事務分配一個唯一的ID
- COMMIT會被自動的分成Prepare和Commit兩個階段。
- Binlog會被當做事務協調者(Transaction Coordinator),Binlog Event會被當做協調者日誌。
想了解2PC,可以參考文檔:【https://en.wikipedia.org/wiki/Two-phase_commit_protocol。】

- 分布式事務ID(XID)

使用2PC時,MySQL會自動的為每一個事務分配一個ID,叫XID。XID是唯一的,每個事務的XID都不相同。XID會分別被Binlog和InnoDB記入日誌中,供恢復時使用。MySQ內部的XID由三部分組成:

- 前綴部分

前綴部分是字元串"MySQLXid"

- Server ID部分

當前MySQL的server_id
- query_id部分

為了保證XID的的唯一性,數字部分使用了query_id。MySQL內部會自動的為每一個語句分配一個query_id,全局唯一。

參考代碼:sql/xa。h的struct xid_t結構。

- 事務的協調者Binlog

Binlog在2PC中充當了事務的協調者(Transaction Coordinator)。由Binlog來通知InnoDB引擎來執行prepare,commit或者rollback的步驟。事務提交的整個過程如下:

1. 協調者准備階段(Prepare Phase)

告訴引擎做Prepare,InnoDB更改事務狀態,並將Redo Log刷入磁碟。

2. 協調者提交階段(Commit Phase)

2.1 記錄協調者日誌,即Binlog日誌。

2.2 告訴引擎做commit。
注意:記錄Binlog是在InnoDB引擎Prepare(即Redo Log寫入磁碟)之後,這點至關重要。

在MySQ的代碼中將協調者叫做tc_log。在MySQL啟動時,tc_log將被初始化為mysql_bin_log對象。參考sql/binlog.cc中的init_server_components():
if (opt_bin_log) tc_log= &mysql_bin_log;

而在事務提交時,會依次執行:
tc_log->prepare();
tc_log->commit();
參考代碼:sql/binlog.cc中的ha_commit_trans()。當mysql_bin_log是tc_log時,prepare和commit的代碼在sql/binlog.cc中:

MYSQL_BIN_LOG::prepare();
MYSQL_BIN_LOG::commit();

-協調者日誌Xid_log_event
作為協調者,Binlog需要將事務的XID記入日誌,供恢復時使用。Xid_log_event有以下幾個特點:
- 僅記錄query_id
因為前綴部分不變,server_id已經記錄在Event Header中,Xid_log_event中只記錄query_id部分。
- 標志事務的結束

在Binlog中相當於一個事務的COMMIT語句。

一個事務在Binlog中看起來時這樣的:
Query_log_event("BEGIN");DML產生的events; Xid_log_event;

- DDL沒有BEGIN,也沒有Xid_log_event 。
- 僅InnoDB的DML會產生Xid_log_event
因為MyISAM不支持2PC所以不能用Xid_log_event ,但會有COMMIT Event。
Query_log_event("BEGIN");DML產生的events;Query_log_event("COMMIT");

問題:Query_log_event("COMMIT")和Xid_log_event 有不同的影響嗎?

- Xid_log_event 中的Xid可以幫助master實現CrashSafe。
- Slave的CrashSafe不依賴Xid_log_event
事務在Slave上重做時,會重新產生XID。所以Slave伺服器的CrashSafe並不依賴於Xid_log_event 。Xid_log_event 和Query_log_event("COMMIT"),只是作為事務的結尾,告訴Slave Applier去提交這個事務。因此二者在Slave上的影響是一樣的。

3 - 恢復(Recovery)
這個機制是如何保證MySQL的CrashSafe的呢,我們來分析一下。這里我們假設用戶設置了以下參數來保證可靠性:

- 恢復前事務的狀態
在恢復開始前事務有以下幾種狀態:
- InnoDB中已經提交
根據前面2PC的過程,可知Binlog中也一定記錄了該事務的的Events。所以這種事務是一致的不需要處理。
- InnoDB中是prepared狀態,Binlog中有該事務的Events。
需要通知InnoDB提交這些事務。
- InnoDB中是prepared狀態,Binlog中沒有該事務的Events。
因為Binlog還沒記錄,需要通知InnoDB回滾這些事務。
- Before InnoDB Prepare
事務可能還沒執行完,因此InnoDB中的狀態還沒有prepare。根據2PC的過程,Binlog中也沒有該事務的events。 需要通知InnoDB回滾這些事務。

- 恢復過程
從上面的事務狀態可以看出:恢復時事務要提交還是回滾,是由Binlog來決定的。
- 事務的Xid_log_event 存在,就要提交。
- 事務的Xid_log_event 不存在,就要回滾。

恢復的過程非常簡單:
- 從Binlog中讀出所有的Xid_log_event
- 告訴InnoDB提交這些XID的事務
- InnoDB回滾其它的事務

㈣ 怎麼執行sql命令

執行sql命令步驟如下:

1、點擊頁面中的【SQL】。

以上就是執行sql命令的步驟。

㈤ 進入PLSQL的命令窗口,輸入SQL語句後,應該如何執行

不知你所用的PL-SQL為哪個版本。以Oralc資料庫開發工具的PL-SQL Developer為示範:用滑鼠選中需要執行的SQL語句,點窗口左邊鑰匙圖標旁的圖標,或直接按F8鍵就能執行。可參見網路經驗PLSQL Developer新手使用教程(圖文教程)http://jingyan..com/article/c85b7a6403acd1003bac950f.html

閱讀全文

與sql命令執行後執行相關的資料

熱點內容
安卓怎麼改自己的微信來電鈴聲 瀏覽:589
mac退出終端命令行 瀏覽:611
拼多多上幾百塊錢的安卓手機怎麼樣 瀏覽:783
vs網站工程編譯很慢 瀏覽:274
合肥拍違章的app叫什麼 瀏覽:766
sw怎麼把總裝配體放在文件夾外 瀏覽:832
ios系統壓縮包後綴 瀏覽:496
按鈕鏈接宏後編譯錯誤 瀏覽:635
華為首席編譯器 瀏覽:175
什麼app可以幫助自己唱歌更好聽 瀏覽:834
pdf解開 瀏覽:251
nginx伺服器需要什麼硬體 瀏覽:204
圖警報命令 瀏覽:494
什麼app能下歌詞 瀏覽:40
歐美程序員的電視劇 瀏覽:44
手機使用萬能命令 瀏覽:396
編譯過程中可以發現拼寫錯誤嗎 瀏覽:420
程序員培訓機構靠譜嗎 瀏覽:955
linuxtags 瀏覽:586
有什麼好用的手環app 瀏覽:779