真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

mysql中怎么執(zhí)行 mysql命令執(zhí)行sql

mysql安裝后怎么使用

在我們?nèi)粘I钪信紶枙龅揭恍┳约翰恢廊绾谓鉀Q的問題,比如使用安裝好的mysql。那么我們應(yīng)該怎樣解決這種自己不知道如何使用安裝好的mysql的情況呢?那么接下來就由我來介紹一下使用安裝好的mysql的步驟吧。

創(chuàng)新互聯(lián)2013年開創(chuàng)至今,先為瑞昌等服務(wù)建站,瑞昌等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為瑞昌企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

本次操作以Dell電腦為例,具體操作步驟如下:

第一步:

首先,打開MySQLWorkbench,雙擊打開即可。打開后的界面如下所示,然后選擇數(shù)據(jù)庫實例,雙擊進(jìn)行登錄。圖中數(shù)據(jù)庫的實例是LocalinstanceMYSQL57

第二步:

然后,輸入用戶名和密碼進(jìn)行登錄。如下圖所示:

第三步:

登錄成功后,界面如下所示。其中,區(qū)域1顯示的是數(shù)據(jù)庫服務(wù)器中已經(jīng)創(chuàng)建的數(shù)據(jù)庫列表。區(qū)域2是關(guān)于數(shù)據(jù)庫的操作列表。區(qū)域三是sql的編輯器和執(zhí)行環(huán)境,區(qū)域4是執(zhí)行結(jié)果的列表

第四步:

在sql的編輯器中輸入測試語句,如圖所示,其中world數(shù)據(jù)庫是mysql自帶的測試數(shù)據(jù)庫,然后選擇執(zhí)行(或者使用快捷鍵ctrl+enter)。執(zhí)行成功后,查詢結(jié)果會顯示在下面的列表中。

第五步:

使用完畢后,直接退出,并且如果無需數(shù)據(jù)庫的后繼操作的話,記得關(guān)掉MySQL的服務(wù)

看了我的方法,現(xiàn)在你學(xué)會如何使用安裝好的mysql了嗎?學(xué)會了的話就快快把這個方法分享出去,讓更多的人知道如何使用安裝好的mysql。以上就是使用安裝好的mysql的步驟。

本文章基于Dell品牌、Windows10系統(tǒng)撰寫的。

mysql 怎么導(dǎo)入/執(zhí)行.SQL(存儲過程)文件?

方法一 進(jìn)入命令行

mysql –u用戶名 –p密碼 –D數(shù)據(jù)庫【sql腳本文件路徑全名】,示例:

mysql –uroot –p123456 -Dtest /home/zj/create_table.sql

注意:

如果在sql腳本文件中使用了use 數(shù)據(jù)庫,則-D數(shù)據(jù)庫選項可以忽略

方法二 進(jìn)入mysql的控制臺后,使用source命令執(zhí)行

Mysqlsource 【sql腳本文件的路徑全名】 或 Mysql\. 【sql腳本文件的路徑全名】,示例:

source /home/zj/create_table.sql

mysql怎么一次執(zhí)行多條SQL語句

工具/材料:NavicatForMysql。

1、首先在桌面上,點擊“NavicatForMysql”圖標(biāo)。

2、然后在該界面中,點擊“新建查詢”按鈕。

3、之后在該界面中,輸入多條SQL語句。

4、接著在該界面中,點擊上方“執(zhí)行”按鈕。

5、最后在該界面中,顯示多條SQL語句執(zhí)行成功。

mysql是怎樣運行的從根兒上理解mysql電子書

《MySQL是怎樣運行的:從根兒上理解 MySQL》采用詼諧幽默的表達(dá)方式,對MySQL的底層運行原理進(jìn)行了介紹,內(nèi)容涵蓋了使用MySQL的同學(xué)在求職面試和工作中常見的一些核心概念。總計22 章,劃分為4個部分。第1部分介紹了MySQL入門的一些知識,比如MySQL的服務(wù)器程序和客戶端程序有哪些、MySQL的啟動選項和系統(tǒng)變量,以及使用的字符集等。第2部分是本書后續(xù)章節(jié)的基礎(chǔ),介紹了MySQL的一些基礎(chǔ)知識,比如記錄、頁面、索引、表空間的結(jié)構(gòu)和用法等。第3部分則與大家在工作中經(jīng)常遇到的查詢優(yōu)化問題緊密相關(guān),介紹了單表查詢、連接查詢的執(zhí)行原理,MySQL基于成本和規(guī)則的優(yōu)化具體指什么,并詳細(xì)分析了Explain語句的執(zhí)行結(jié)果。第4部分則是與MySQL中的事務(wù)和鎖相關(guān),介紹了事務(wù)概念的來源,MySQL是如何實現(xiàn)事務(wù)的,包括redo日志、undo日志、MVCC、各種鎖的細(xì)節(jié)等。

盡管《MySQL是怎樣運行的:從根兒上理解 MySQL》在寫作時參考的MySQL源代碼版本是5.7.22,但是大部分內(nèi)容與具體的版本號并沒有多大關(guān)系。無論是很早之前就已身居MySQL專家的人員,還是希望進(jìn)一步提升技能的DBA,甚至是三五年后才會入行的“萌新”,本書都是他們徹底了解MySQL運行原理的優(yōu)秀書

簡介mysql之mysql語句執(zhí)行流程

1.一條查詢語句如何執(zhí)行?

2.一條更新語句如何執(zhí)行?

3.innodb的redolog是什么?

4.什么是寫緩沖

5.寫緩沖一定好嗎?

6.什么情況會引發(fā)刷臟頁

關(guān)于一條mysql查詢語句在mysql中的執(zhí)行流程

如select name from test where id=10;

1.連接器---先與mysql服務(wù)端連接器建立連接,若查詢緩存命中則直接返回 (查詢緩存的弊端:查詢緩存的失效非常頻繁,只要有對一個表的更新,這個表上所有的查詢緩存都會被清空。)

2.分析器---詞法分析告訴服務(wù)端你要干什么(我要找 test表中id為10的名字) ( 其中sql語法錯誤在這塊暴露 )

3.優(yōu)化器---服務(wù)端會思考該怎么執(zhí)行最優(yōu)(索引的選擇)

4.執(zhí)行器---檢查用戶對庫對表的權(quán)限

5.存儲引擎--存儲數(shù)據(jù),提供讀寫接口

以update a set name=1 where id=1;

主要區(qū)別在于在查詢到數(shù)據(jù)之后(select name from a where id=1),如果是innodb引擎它會進(jìn)行日志的兩階段提交:

1.開啟事務(wù),寫入redolog(innodb引擎特有),并更新內(nèi)存

3.寫入binlog,提交事務(wù),commit

我們知道m(xù)ysql數(shù)據(jù)存儲包含內(nèi)存與磁盤兩個部分,innodb是按數(shù)據(jù)頁(通常為16k)從磁盤讀取到內(nèi)存中的(剩余操作在內(nèi)存中執(zhí)行),當(dāng)要更新數(shù)據(jù)時,若目標(biāo)數(shù)據(jù)的數(shù)據(jù)頁剛好在內(nèi)存中,則直接更新。不在呢?

將這個更新操作(也可能是插入) 緩存在change buffer中 (redolog也會記錄這個change buffer操作)等到下一次查詢要用到這些數(shù)據(jù)時,再執(zhí)行這些操作,改變數(shù)據(jù)(稱為合并操作記錄稱為merge)。

innodb_change_buffer_max_size

innodb_change_buffering

先介紹兩個概念

因為redolog是環(huán)形日志,當(dāng)redolog寫滿時,就需要“擦掉”開頭的一部分?jǐn)?shù)據(jù)來達(dá)到循環(huán)寫,這里的擦掉指,指將redolog日志的checkpoint位置從 CP推進(jìn)到CP‘ ,同時將兩點之間的臟頁刷到磁盤上(flush操作),此時系統(tǒng)要停止所有的更新操作(防止更新操作丟失)

1.系統(tǒng)內(nèi)存不足。當(dāng)要讀取新的內(nèi)存頁時就要淘汰一些數(shù)據(jù)頁,如果淘汰的正好是臟頁,就要執(zhí)行一次flush操作

2.Mysql認(rèn)為系統(tǒng)處于“空閑狀態(tài)”

3.正常關(guān)閉Mysql

上述后兩者場景(系統(tǒng)空閑和正常關(guān)閉)對于性能都沒太大影響。

當(dāng)為第一種redolog寫滿時,系統(tǒng)無法執(zhí)行更新操作,所有操作都會堵塞

當(dāng)為第二種內(nèi)存不夠用時,如果淘汰臟頁太多,影響mysql響應(yīng)時間

后兩者刷臟頁會影響性能,所以Mysql需要有刷臟頁控制策略,可以從以下幾個設(shè)置項考慮

1.設(shè)置innodb_io_capacity告訴innodb所在主機的IO能力

MySql中Sql的執(zhí)行過程

如果查詢緩存沒有命中,那么SQL請求會進(jìn)入分析器,分析器是用來分辨SQL語句的執(zhí)行目的,其執(zhí)行過程大致分為兩步:

表1 語法分析關(guān)鍵字然后再通過語法規(guī)則解析,判斷輸入的SQL 語句是否滿足MySQL語法,并且生成圖5的語法樹。由SQL語句生成的四個單詞中,識別出兩個關(guān)鍵字,分別是select 和from。根據(jù)MySQL的語法Select 和 from之間對應(yīng)的是fields 字段,下面應(yīng)該掛接username;在from后面跟隨的是Tables字段,其下掛接的是userinfo。

優(yōu)化器的作用是對SQL進(jìn)行優(yōu)化,生成最有的執(zhí)行方案。如圖6所示,前面提到的SQL解析器通過語法分析和語法規(guī)則生成了SQL語法樹。這個語法樹作為優(yōu)化器的輸入,而優(yōu)化器(黃色的部分)包含了邏輯變換和代價優(yōu)化兩部分的內(nèi)容。在優(yōu)化完成以后會生成SQL執(zhí)行計劃作為整個優(yōu)化過程的輸出,交給執(zhí)行器在存儲引擎上執(zhí)行。

所處的位置如上圖所示,這節(jié)的重點在優(yōu)化器中的邏輯變換和代價優(yōu)化上。

邏輯變換也就是在關(guān)系代數(shù)基礎(chǔ)上進(jìn)行變換,其目的是為了化簡,同時保證SQL變化前后的結(jié)果一致,也就是邏輯變化并不會帶來結(jié)果集的變化。其主要包括以下幾個方面:

這樣講概念或許有些抽象,通過圖7 來看看邏輯變化如何在SQL中執(zhí)行的吧。

如圖7所示,從上往下共有4個步驟:

1. 針對存在的SQL語句,首先通過“否定消除”,去掉條件判斷中的“NOT”。語句由原來的“or”轉(zhuǎn)換成“and”,并且大于小于符號進(jìn)行變號。藍(lán)色部分為修改前的SQL,紅色是修改以后的SQL。2. 等值傳遞,這一步很好理解分別降”t2.a=9” 和”t2.b=5”分別替換掉SQL中對應(yīng)的值。3. 接下來就是常量表達(dá)式計算,將“5+7”計算得到“12”。4. 最后是常量表達(dá)式計算后的化簡,將”9=10”化簡為”true”帶入到最終的SQL表達(dá)式中完成優(yōu)化。

代價優(yōu)化是用來確定每個表,根據(jù)條件是否應(yīng)用索引,應(yīng)用哪個索引和確定多表連接的順序等問題。為了完成代價優(yōu)化,需要找到一個代價最小的方案。因此,優(yōu)化器是通過基于代價的計算方法來決定如何執(zhí)行查詢的(Cost-based Optimization)。簡化的過程如下:

這里將配置操作的代價分為MySQL 服務(wù)層和MySQL 引擎層,MySQL 服務(wù)層主要是定義CPU的代價,而MySQL 引擎層主要定義IO代價。MySQL 5.7 引入了兩個系統(tǒng)表mysql.server_cost和mysql.engine_cost來分別配置這兩個層的代價。如下:MySQL 服務(wù)層代價保存在表server_cost中,其具體內(nèi)容如下:

由上可以看出創(chuàng)建臨時表的代價是很高的,尤其是內(nèi)部的myisam或innodb臨時表。MySQL 引擎層代價保存在表engine_cost中,其具體內(nèi)容如下:

目前io_block_read_cost和memory_block_read_cost默認(rèn)值均為1,實際生產(chǎn)中建議酌情調(diào)大memory_block_read_cost,特別是對普通硬盤的場景。MySQL會根據(jù)SQL查詢生成的查詢計劃中對應(yīng)的操作從上面兩張代價表中查找對應(yīng)的代價值,并且進(jìn)行累加形成最終執(zhí)行SQL計劃的代價。再將多種可能的執(zhí)行計劃進(jìn)行比較,選取最小代價的計劃執(zhí)行。

當(dāng)分析器生成查詢計劃,并且經(jīng)過優(yōu)化器以后,就到了執(zhí)行器。執(zhí)行器會選擇執(zhí)行計劃開始執(zhí)行,但在執(zhí)行之前會校驗請求用戶是否擁有查詢的權(quán)限,如果沒有權(quán)限,就會返回錯誤信息,否則將會去調(diào)用MySQL引擎層的接口,執(zhí)行對應(yīng)的SQL語句并且返回結(jié)果。例如SQL:“SELECT * FROM userinfo WHERE username = 'Tom';“假設(shè) “username“ 字段沒有設(shè)置索引,就會調(diào)用存儲引擎從第一條開始查,如果碰到了用戶名字是” Tom“, 就將結(jié)果集返回,沒有查找到就查看下一行,重復(fù)上一步的操作,直到讀完整個表或者找到對應(yīng)的記錄。需要注意SQL語句的執(zhí)行順序并不是按照書寫順序來的,順序的定義會在分析器中做好,一般是按照如下順序:

如果命中的記錄比較多,應(yīng)用會從MySql Server一批批獲取數(shù)據(jù)

本文從MySQL中SQL語句的執(zhí)行過程作為切入點,首先介紹了查詢請求的執(zhí)行流程,其中將MySQL的處理分為MySQL Server層和MySQL存儲引擎層。通過介紹SQL語句的流轉(zhuǎn),引出了后面要介紹的5大組件,他們分別是:連接器、查詢緩存、分析器、優(yōu)化器、執(zhí)行器。后面的內(nèi)容中對每個組件進(jìn)行了詳細(xì)的介紹。連接器,負(fù)責(zé)身份認(rèn)證和權(quán)限鑒別;查詢緩存,將查詢的結(jié)果集進(jìn)行緩存,提高查詢效率;分析器,對SQL語句執(zhí)行語法分析和語法規(guī)則,生成語法樹和執(zhí)行計劃;優(yōu)化器,包括邏輯變換和代價優(yōu)化;執(zhí)行器,在檢查用戶權(quán)限以后對數(shù)據(jù)進(jìn)行逐條查詢,整個過程遵守SQL語句的執(zhí)行順序。


當(dāng)前名稱:mysql中怎么執(zhí)行 mysql命令執(zhí)行sql
網(wǎng)站網(wǎng)址:http://weahome.cn/article/hhggii.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部