1、函數(shù)必須指定返回值,且參數(shù)默認(rèn)為IN類型。

專業(yè)從事成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計,高端網(wǎng)站制作設(shè)計,小程序制作,網(wǎng)站推廣的成都做網(wǎng)站的公司。優(yōu)秀技術(shù)團隊竭力真誠服務(wù),采用HTML5+CSS3前端渲染技術(shù),自適應(yīng)網(wǎng)站建設(shè),讓網(wǎng)站在手機、平板、PC、微信下都能呈現(xiàn)。建站過程建立專項小組,與您實時在線互動,隨時提供解決方案,暢聊想法和感受。
2、存儲過程沒返回值,參數(shù)可以是 IN,OUT,IN OUT類型,有的人可能會理解成OUT 也算是返回值。
3、調(diào)用方式:函數(shù) select my_fun() ;過程 call my_pro( ) ;
4、DEMO
mysql call my_pro(1,2,@c);
Query OK, 0 rows affected (0.00 sec)
mysql select @c;
+------+
| @c |
+------+
| 3 |
+------+
1 row in set (0.00 sec)
mysql select my_fun(1,2);
+-------------+
| my_fun(1,2) |
+-------------+
| 3 |
+-------------+
1 row in set (0.00 sec)
使用MySQL編程和SQL Server基本思想是一致的,語法有較大的區(qū)別。SQL Server不管是條件、循環(huán)等區(qū)塊仍然要使用begin與end作為起始和結(jié)束的標(biāo)識,而MySQL則直接用END something(如while,if,loop),當(dāng)然,由于自己接觸MySQL并不長,沒有使用SQL Server那么熟練,所以寫這些也是非常基礎(chǔ)的部分,而在實際問題中會千變?nèi)f化,所以還是需要更多的實踐來不斷提高。
1、啟動MySQL服務(wù)器 實際上上篇已講到如何啟動MySQL。兩種方法: 一是用winmysqladmin,如果機器啟動時已自動運行,則可直接進入下一步操作。 二是在DOS方式下運行 d:/mysql/bin/mysqld 2、進入mysql交互操作界面 在DOS方式下,運行: d:/mysql/bin/mysql -u root -p 出現(xiàn)提示符,此時已進入mysql的交互操作方式。 如果出現(xiàn) "ERROR 2003: Can‘t connect to MySQL server on ‘localhost‘ (10061)“,說明你的MySQL還沒有啟動。 3、退出MySQL操作界面 在mysql提示符下輸入quit可以隨時退出交互操作界面: mysql quit Bye 你也可以用control-D退出。
創(chuàng)建存儲過程
mysql
delimiter
$
--
delimiter
$是設(shè)置
$為命令終止符號,代替默認(rèn)的分號,因為分號有其他用處.
mysql
create
procedure
sp_test(IN
pi_id
int,
OUT
po_name
varchar(10))
-
begin
-
select
*
from
test.tb_test;
-
select
tb_test.name
into
po_name
from
test.tb_test
where
tb_test.id
=
pi_id;
-
end
-
$
Query
OK,
rows
affected
(0.00
sec)
mysql
delimiter
;
--
恢復(fù)分號作為分隔終止符號
5.調(diào)用存儲過程
mysql
set
@po_name='';
Query
OK,
rows
affected
(0.00
sec)
mysql
call
sp_test(1,@po_name);
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引擎它會進行日志的兩階段提交:
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ù)來達到循環(huán)寫,這里的擦掉指,指將redolog日志的checkpoint位置從 CP推進到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能力
                網(wǎng)頁題目:mysql的過程怎么寫 mysql語句怎么寫
                
                標(biāo)題路徑:http://www.yijiale78.com/article34/dodecse.html
            
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供、手機網(wǎng)站建設(shè)、企業(yè)建站、面包屑導(dǎo)航、建站公司、定制網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
