1.在運(yùn)行里輸入cmd,進(jìn)入命令提示窗口
成都創(chuàng)新互聯(lián)主要從事網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站設(shè)計(jì)、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)龍華,10年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來(lái)電咨詢建站服務(wù):13518219792
2.在我的電腦里找到安裝mysql的地方,下面有一個(gè)bin目錄
3.在命令提示符窗口下cd 到mysql 的bin目錄下
你的問(wèn)題太泛泛了,“MYSQL的程序”你指的是什么?是MYSQL的 存儲(chǔ)過(guò)程??您最好是具體問(wèn)題具體問(wèn),你這樣提問(wèn)的話大家都不知道你想要什么!
mysql soure example.sql里的soure寫錯(cuò)了應(yīng)該是source!!!!example.sql是你實(shí)現(xiàn)先編輯好的文本內(nèi)容,內(nèi)容可以是創(chuàng)建一個(gè)數(shù)據(jù)庫(kù),然后再數(shù)據(jù)庫(kù)下建立一個(gè)或多個(gè)數(shù)據(jù)表,再往表里插入一些記錄??!然后再寫個(gè)存儲(chǔ)過(guò)程完成一些簡(jiǎn)單的功能,比如把A表里的內(nèi)容插入到B表等等(可以加內(nèi)容存在就修改不存在就插入等判斷)!!建立一個(gè).SQL文件就是為了方便?。‰S便舉個(gè)例子:在D盤根目錄下用記事本建立個(gè)example.sql文件,內(nèi)容如下:
CREATE database name ;
use name;
CREATE TABLE a (
user_id int(11) DEFAULT NULL,
name char(11) DEFAULT NULL,
UNIQUE KEY USER_ID (user_id)
);
insert into a (user_id,name) values (1,'aaa'),(2,'bbb');
CREATE TABLE b (
user_id int(11) DEFAULT NULL,
name char(11) DEFAULT NULL,
UNIQUE KEY USER_ID (user_id)
);
insert into b (user_id,name) values (1,'xxx'),(3,'ccc');
DELIMITER $$
DROP PROCEDURE IF EXISTS qq$$
CREATE PROCEDURE qq()
begin
declare p_user_id varchar(6);
declare p_name varchar(6);
declare cursor_flag int default 0;
declare user_nrb cursor for select user_id,name from a;
declare continue handler for sqlstate '02000' set cursor_flag = 1;
open user_nrb;
repeat
fetch user_nrb into p_user_id,p_name;
if not cursor_flag then
if not exists (select * from b where user_id=p_user_id) then
insert into b(user_id,name)values(p_user_id,p_name);
else
update b set name=p_name where user_id=p_user_id;
end if;
end if;
until cursor_flag end repeat;
close user_nrb;
end$$
DELIMITER ;
順序是建立名為name的數(shù)據(jù)庫(kù),其下建立倆表A和B,為A表插入用戶1和2,為B表插入用戶1,3?。≡俳⒚麨镼Q的存儲(chǔ)過(guò)程,功能是把a(bǔ)表的用戶導(dǎo)入到B表,如果A的用戶號(hào)再B里沒(méi)有直接插入,如果A里的用戶號(hào)已經(jīng)在B表里了那就改變B表里相應(yīng)用戶的名字?。〈蟾攀沁@么個(gè)過(guò)程?。≡贛YSQL自帶的客戶端導(dǎo)入剛才建立的example.sql文件,順序是:開(kāi)始——程序——MYSQL——MYSQL SERVER5.1——MYSQL COMMAND LINE CLIENT 窗口里輸入ROOT用戶密碼在光標(biāo)處輸入source d:\example.sql!!最后再執(zhí)行存儲(chǔ)過(guò)程,敲call qq;回車?。?!
驗(yàn)證方法是敲select * from b;回車!!可以發(fā)現(xiàn)B表由本來(lái)插入的2條記錄變成3條記錄,而且用戶1的名字也從xxx變成aaa了?。。。?/p>
希望對(duì)你有幫助!另外最重要的是MYSQL有一些很好的圖形界面客戶端工具,不用這個(gè)DOS界面的東西,下載個(gè)sqlyog什么的軟件裝上,基本一啟動(dòng)就會(huì)用了的東西!在SQLYOG的界面直接把example.sql里的內(nèi)容復(fù)制過(guò)來(lái)粘貼后按F5鍵運(yùn)行即可?。?!
Mysql分客戶端和服務(wù)端。成功安裝后,在服務(wù)器端,保證mysqld服務(wù)成功啟動(dòng)后,便可以通過(guò)客戶端工具訪問(wèn)mysql了。
在命令行可通過(guò)以下命令登陸mysql:
mysql
-uroot
-ppassword
(-u指定用戶名,-p指定密碼)
另外也可以通過(guò)基于瀏覽器的工具訪問(wèn)mysql,如phpmyadmin。
1.一條查詢語(yǔ)句如何執(zhí)行?
2.一條更新語(yǔ)句如何執(zhí)行?
3.innodb的redolog是什么?
4.什么是寫緩沖
5.寫緩沖一定好嗎?
6.什么情況會(huì)引發(fā)刷臟頁(yè)
關(guān)于一條mysql查詢語(yǔ)句在mysql中的執(zhí)行流程
如select name from test where id=10;
1.連接器---先與mysql服務(wù)端連接器建立連接,若查詢緩存命中則直接返回 (查詢緩存的弊端:查詢緩存的失效非常頻繁,只要有對(duì)一個(gè)表的更新,這個(gè)表上所有的查詢緩存都會(huì)被清空。)
2.分析器---詞法分析告訴服務(wù)端你要干什么(我要找 test表中id為10的名字) ( 其中sql語(yǔ)法錯(cuò)誤在這塊暴露 )
3.優(yōu)化器---服務(wù)端會(huì)思考該怎么執(zhí)行最優(yōu)(索引的選擇)
4.執(zhí)行器---檢查用戶對(duì)庫(kù)對(duì)表的權(quán)限
5.存儲(chǔ)引擎--存儲(chǔ)數(shù)據(jù),提供讀寫接口
以u(píng)pdate a set name=1 where id=1;
主要區(qū)別在于在查詢到數(shù)據(jù)之后(select name from a where id=1),如果是innodb引擎它會(huì)進(jìn)行日志的兩階段提交:
1.開(kāi)啟事務(wù),寫入redolog(innodb引擎特有),并更新內(nèi)存
3.寫入binlog,提交事務(wù),commit
我們知道m(xù)ysql數(shù)據(jù)存儲(chǔ)包含內(nèi)存與磁盤兩個(gè)部分,innodb是按數(shù)據(jù)頁(yè)(通常為16k)從磁盤讀取到內(nèi)存中的(剩余操作在內(nèi)存中執(zhí)行),當(dāng)要更新數(shù)據(jù)時(shí),若目標(biāo)數(shù)據(jù)的數(shù)據(jù)頁(yè)剛好在內(nèi)存中,則直接更新。不在呢?
將這個(gè)更新操作(也可能是插入) 緩存在change buffer中 (redolog也會(huì)記錄這個(gè)change buffer操作)等到下一次查詢要用到這些數(shù)據(jù)時(shí),再執(zhí)行這些操作,改變數(shù)據(jù)(稱為合并操作記錄稱為merge)。
innodb_change_buffer_max_size
innodb_change_buffering
先介紹兩個(gè)概念
因?yàn)閞edolog是環(huán)形日志,當(dāng)redolog寫滿時(shí),就需要“擦掉”開(kāi)頭的一部分?jǐn)?shù)據(jù)來(lái)達(dá)到循環(huán)寫,這里的擦掉指,指將redolog日志的checkpoint位置從 CP推進(jìn)到CP‘ ,同時(shí)將兩點(diǎn)之間的臟頁(yè)刷到磁盤上(flush操作),此時(shí)系統(tǒng)要停止所有的更新操作(防止更新操作丟失)
1.系統(tǒng)內(nèi)存不足。當(dāng)要讀取新的內(nèi)存頁(yè)時(shí)就要淘汰一些數(shù)據(jù)頁(yè),如果淘汰的正好是臟頁(yè),就要執(zhí)行一次flush操作
2.Mysql認(rèn)為系統(tǒng)處于“空閑狀態(tài)”
3.正常關(guān)閉Mysql
上述后兩者場(chǎng)景(系統(tǒng)空閑和正常關(guān)閉)對(duì)于性能都沒(méi)太大影響。
當(dāng)為第一種redolog寫滿時(shí),系統(tǒng)無(wú)法執(zhí)行更新操作,所有操作都會(huì)堵塞
當(dāng)為第二種內(nèi)存不夠用時(shí),如果淘汰臟頁(yè)太多,影響mysql響應(yīng)時(shí)間
后兩者刷臟頁(yè)會(huì)影響性能,所以Mysql需要有刷臟頁(yè)控制策略,可以從以下幾個(gè)設(shè)置項(xiàng)考慮
1.設(shè)置innodb_io_capacity告訴innodb所在主機(jī)的IO能力
1、利用navicat新建數(shù)據(jù)庫(kù),也可采取其他方式。
2、創(chuàng)建數(shù)據(jù)庫(kù),填入數(shù)據(jù)庫(kù)名稱。
3、找到mysql的安裝文件的bin文件。
4、找到所要導(dǎo)入的sql的文件夾。
5、用win+r或者開(kāi)始-菜單-運(yùn)行,輸入cmd打開(kāi)命令行。
6、輸入d:回車,切換到D盤,輸入cd ?+mysql安裝路徑下bin文件夾位置。
7、輸入u 后面代表mysql數(shù)據(jù)庫(kù)用戶名 p后面是密碼 ?,“testwei“代表導(dǎo)入的數(shù)據(jù)庫(kù)名稱,后面就是導(dǎo)入數(shù)據(jù)庫(kù)的sql文件。
8、打開(kāi)navicat,看到數(shù)據(jù)庫(kù)中,已經(jīng)導(dǎo)入數(shù)據(jù),證明,上述操作成功。
《MySQL是怎樣運(yùn)行的:從根兒上理解 MySQL》采用詼諧幽默的表達(dá)方式,對(duì)MySQL的底層運(yùn)行原理進(jìn)行了介紹,內(nèi)容涵蓋了使用MySQL的同學(xué)在求職面試和工作中常見(jiàn)的一些核心概念。總計(jì)22 章,劃分為4個(gè)部分。第1部分介紹了MySQL入門的一些知識(shí),比如MySQL的服務(wù)器程序和客戶端程序有哪些、MySQL的啟動(dòng)選項(xiàng)和系統(tǒng)變量,以及使用的字符集等。第2部分是本書(shū)后續(xù)章節(jié)的基礎(chǔ),介紹了MySQL的一些基礎(chǔ)知識(shí),比如記錄、頁(yè)面、索引、表空間的結(jié)構(gòu)和用法等。第3部分則與大家在工作中經(jīng)常遇到的查詢優(yōu)化問(wèn)題緊密相關(guān),介紹了單表查詢、連接查詢的執(zhí)行原理,MySQL基于成本和規(guī)則的優(yōu)化具體指什么,并詳細(xì)分析了Explain語(yǔ)句的執(zhí)行結(jié)果。第4部分則是與MySQL中的事務(wù)和鎖相關(guān),介紹了事務(wù)概念的來(lái)源,MySQL是如何實(shí)現(xiàn)事務(wù)的,包括redo日志、undo日志、MVCC、各種鎖的細(xì)節(jié)等。
盡管《MySQL是怎樣運(yùn)行的:從根兒上理解 MySQL》在寫作時(shí)參考的MySQL源代碼版本是5.7.22,但是大部分內(nèi)容與具體的版本號(hào)并沒(méi)有多大關(guān)系。無(wú)論是很早之前就已身居MySQL專家的人員,還是希望進(jìn)一步提升技能的DBA,甚至是三五年后才會(huì)入行的“萌新”,本書(shū)都是他們徹底了解MySQL運(yùn)行原理的優(yōu)秀書(shū)