mysql - 存儲(chǔ)過程在實(shí)際項(xiàng)目中用的多嗎?
問題描述
我發(fā)現(xiàn)很多教科書,數(shù)據(jù)庫教程視頻都涉及到了存儲(chǔ)過程,但是我看過很多開源的php項(xiàng)目,里面幾乎就沒有用到存儲(chǔ)過程啊,我看過java項(xiàng)目倒是有部分項(xiàng)目用到過存儲(chǔ)過程,這是為什么呢?
已經(jīng)從業(yè)或者開發(fā)過大型項(xiàng)目的程序員們你們?cè)趯?shí)際工作中用到過他嗎?
還有就是存儲(chǔ)過程里面的邏輯幾乎我都可以用程序(java,php)寫,為什么還要直接在數(shù)據(jù)庫里面寫呢?(換句話說:存儲(chǔ)過程的意義是什么?)
問題解答
回答1:一、存儲(chǔ)過程是非常有用滴。例如,在常見的登錄場(chǎng)景中,需要記錄用戶的登入記錄,你可以使用編程語言來實(shí)現(xiàn):
db.connect( 'db_host' ).execute_sql( 'select count(*) from user_info_table where username = ’you’ and pass=’123’ ' ); db.connect( 'db_host' ).execute_sql( 'insert into login_table( user_name, log_time )values( ’you’, ’2017_01_05’ ) ' );
在這里,第1步首先判斷用戶存不存在,第2步記錄用戶登錄日志。
存儲(chǔ)過程實(shí)現(xiàn):login_user_and_save_result()的功能是執(zhí)行用戶登錄操作、并記錄用戶的登錄日志。
db.connect( 'db_host' ).execute_sql( 'call login_user_and_save_result(’you’, ’123’) ' );
區(qū)別在于,編程語言實(shí)現(xiàn)需要執(zhí)行2次數(shù)據(jù)庫連接connect操作、2次編譯sql操作execute_sql;login_user_and_save_result()則只需要1次connect,0次編譯execute_sql操作,因?yàn)榇鎯?chǔ)過程在創(chuàng)建之初就已經(jīng)編譯好了,只需要傳參數(shù)就可以了。這樣在用戶量逐步增長的情況下,存儲(chǔ)過程可以為服務(wù)器省很多帶寬、系統(tǒng)資源消耗,優(yōu)勢(shì)會(huì)慢慢顯示出來。
如果,你的boss讓你再加一層邏輯,只允許用戶3次登錄嘗試,3次失敗后,不允許登錄。在編程語言級(jí)別的數(shù)據(jù)庫操作會(huì)變的更加復(fù)雜一點(diǎn)。
arr_result = db.connect( 'db_host' ).execute_sql( 'select count(*) from user_info_table where username = ’you’ and pass=’123’ and enable_login = 1' ); // if( arr_result != 1 ) { //更新登入失敗次數(shù) db.connect( 'db_host' ).execute_sql( 'insert user_login_fail(username, pass) values( ’you’, ’pass’ ) ' ); } fail_count = db.connect( ’db_host’ ).execute_sql( 'select count(*) from user_login_fail where username = ’you’' ); if( fail_count > 3 ) { db.connect( 'db_host' ).execute_sql( 'update user_info_table set enable_login = 0' ); }
在這里,你可以發(fā)現(xiàn)編程語言需要頻繁的連接db、或者說要和數(shù)據(jù)庫保持長時(shí)間的網(wǎng)絡(luò)連接。如果,你把這些登錄邏輯都放在login_user_and_result()里實(shí)現(xiàn),你要做的只是傳入?yún)?shù)username、pass,系統(tǒng)也只需要做1次連接db、0次編譯,簡(jiǎn)單很多。
二、存儲(chǔ)過程的作用不只在資源消耗上。現(xiàn)在,你的程序有兩種方式登錄,一種是在web端登錄,一種是原生client端登錄。假設(shè),web端是使用java web實(shí)現(xiàn),client端是使用visual c++來實(shí)現(xiàn)。如果,java web 和 visual c++在登錄的時(shí)候都調(diào)用login_user_and_result(),就可以保持用戶一致的登錄行為,避免開發(fā)人員分別實(shí)現(xiàn)導(dǎo)致其他問題。其實(shí),你還可以給存儲(chǔ)過程添加各種數(shù)據(jù)庫級(jí)別的權(quán)限,統(tǒng)一控制登入權(quán)限。
回答2:我覺得存儲(chǔ)過程主要有兩個(gè)優(yōu)勢(shì)。一是在數(shù)據(jù)庫端執(zhí)行,避免網(wǎng)絡(luò)通訊開銷,從而效率較高。二是存儲(chǔ)過程可以直接利用數(shù)據(jù)庫提供的一些高級(jí)抽象,比如事務(wù)、觸發(fā)器、重寫規(guī)則等。
如果完全不用存儲(chǔ)過程,數(shù)據(jù)庫只是一個(gè)提供增刪改的存儲(chǔ)后端罷了,它提供的高級(jí)功能就浪費(fèi)了。可以用存儲(chǔ)過程構(gòu)建業(yè)務(wù)功能,前端只是調(diào)用這些功能,類似于API的效果。
回答3:實(shí)施,運(yùn)維可以自己改,不然屁大點(diǎn)業(yè)務(wù)都要返回到開發(fā)這邊改代碼,編譯,發(fā)補(bǔ)丁
回答4:我的項(xiàng)目中,沒有使用到存儲(chǔ)過程。倒是用過視圖!項(xiàng)目大些的公司可能有些需要,有專門Dba的單位!
回答5:ods,數(shù)據(jù)倉庫等傳統(tǒng)數(shù)據(jù)中心的數(shù)據(jù)批處理,或者olap還是會(huì)用存儲(chǔ)過程的
回答6:有DBA用存儲(chǔ)過程或者簡(jiǎn)單的邏輯用,日志寫到數(shù)據(jù)庫中...個(gè)人覺得寫到代碼里簡(jiǎn)單些
回答7:效率高,有時(shí)候職責(zé)分得很細(xì)的時(shí)候后端未必能隨意訪問數(shù)據(jù)庫
回答8:我所在的項(xiàng)目里存儲(chǔ)過程是用得比較多,特別是報(bào)表,大部分用存儲(chǔ)過程。除了上面的幾個(gè)優(yōu)點(diǎn),還有就是存儲(chǔ)過程的擴(kuò)展性會(huì)比較好,比如說跨庫、分表union,一些動(dòng)態(tài)拼接sql的,存儲(chǔ)過程方便,也直觀,對(duì)于日后分布式,也只是在存儲(chǔ)過程內(nèi)拼接修改。
回答9:我一般用來做數(shù)據(jù)整理,遷移。比如網(wǎng)站整改,數(shù)據(jù)結(jié)構(gòu)變了,某某表被拆了,某某表合并了,某某字段數(shù)據(jù)格式有變等等情況,反正我只在站點(diǎn)升級(jí)的時(shí)候需要用到。其他查詢一般能用代碼實(shí)現(xiàn)的都不想用存儲(chǔ)過程實(shí)現(xiàn)
回答10:有逼格的公司,會(huì)專門有DBA這樣一個(gè)職位,才看不上程序員寫的SQL,復(fù)雜的業(yè)務(wù)寫個(gè)幾千行存儲(chǔ)過程實(shí)現(xiàn)。存儲(chǔ)過程本身的優(yōu)點(diǎn)就不具體說了。
相關(guān)文章:
1. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實(shí)現(xiàn)存在即更新應(yīng)該使用哪個(gè)標(biāo)簽?2. 安裝了“PHP工具箱”,但只能以“游客”身份登錄3. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。4. 跨類調(diào)用后,找不到方法5. sql語句 - 如何在mysql中批量添加用戶?6. PHP類屬性聲明?7. 在應(yīng)用配置文件 app.php 中找不到’route_check_cache’配置項(xiàng)8. 哭遼 求大佬解答 控制器的join方法怎么轉(zhuǎn)模型方法9. 編輯成功不顯示彈窗10. phpstady在win10上運(yùn)行
