日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL工作笔记-使用事件和存储过程定时更新某表数据

發布時間:2025/3/15 数据库 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL工作笔记-使用事件和存储过程定时更新某表数据 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

目錄

?

?

基本概念

演示及源碼


?

基本概念

因為要看某展示軟件的效果,上午用了Qt實時對表進行更新操作!

這是非常low的表現。其中的一個原因就是效率問題!

?

Qt工作筆記-Qt連接Mysql數據庫,檢索及修改表數據

https://blog.csdn.net/qq78442761/article/details/88592455

?

這里可以使用存儲過程,對表進行批量更新!

然后再用事件,設置一個每秒刷新,是不是感覺很爽歪歪!

?

下面給出使用存儲過程的優勢!

? ? ? ? ? ? ? ? ? ?1.可增強SQL語言的功能和靈活性

? ? ? ? ? ? ? ? ? ?2.良好的封裝性

? ? ? ? ? ? ? ? ? ?3.高性能

? ? ? ? ? ? ? ? ? ?4.可減少網絡流量

? ? ? ? ? ? ? ? ? ?5.存儲過程可以作為一種安全機制來確保數據庫的安全性和數據的完整性

【回憶這個,還是我大二的時候考計算機二級mysql學過的,如今終于在項目中用到了,不容易啊,看來大學里面的東西還是很有用的,只是沒有項目進行實踐,而工程學科,實踐>理論】

?

演示及源碼

有如下兩個表:

兩張表結構分別如下:

目前表中存在的數據有!

現在來寫一個存儲過程,實現輸入一個id,對2張表中指定id進行更新!

delimiter $$ create procedure spUpdateValue(in cid int) begin update datasample set value=RAND()*99999 where idval=cid; update circle set isRun=RAND()*1 where id=cid; end $$ delimiter ;

運行截圖如下:

調用下看看,然后在看看數據變了沒!

從這里可以發現的確是更新了,現在修改下存儲過程,實現批量更新!

這里只要把限定符去掉就可以了!

delimiter $$ create procedure spUpdateValue() begin update datasample set value=RAND()*99999; update circle set isRun=RAND()*1; end $$ delimiter ;

運行截圖如下:

這里現在來寫一個事件,讓其每秒調用一次存儲過程!

create event updateEvent on schedule every 1 second on completion PRESERVE do call spUpdateValue;


當為on completion preserve 的時候,當event到期了,event會被disable,但是該event還是會存在
當為on completion not preserve的時候,當event到期的時候,該event會被自動刪除掉.。

?

這里要注意,mysql默認是不會開啟事件,需要輸入

set global event_scheduler=on;

開啟事件!

運行截圖如下:

?

總結

以上是生活随笔為你收集整理的MySQL工作笔记-使用事件和存储过程定时更新某表数据的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。