国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

MySQL如何記錄一張表格的插入操作次數

瀏覽:104日期:2022-06-13 16:02:48

問題描述

要求是表里插入記錄時,name是日期+當天它是第幾個插入的,比如20170408003。

我的解決辦法是:mysql里存一個count;一個觸發器,插入一條記錄后count+1;一個事件,每天0點count=0;每次插入數據,name是當前日期+(count+1)。

可是問題來了,這個count存在哪里呢?系統變量是不能創建的,用戶變量是會話級別的,客戶端連接斷了就沒了。

所以這個count該存在哪里呢,難不成新建一個表來存?

求大神指點~

問題解答

回答1:

這個問題只要統計次數的話設一個自增id列就好了嘛,加一個時間戳字段,沒必要一定放一個字段里吧 要做統計的時候取每天的最大和最小id做個減法就出來了

回答2:

我覺得再存一張表吧

回答3:

個人可能會通過文件緩存做 (通過數據表,redis之類的邏輯差不多)

緩存數據 [’count’ => 0, ’day’ => ’yyy-mm-dd’] //count => 記錄當前記錄數, day =>當前記錄的是哪一天的數據

每次有新數據插入的時候根據day 確認count是否需要重置并更新day為當前日期

count++

更新緩存文件

如果有redis的話還是用它吧.

回答4:

該問題并非統計,實則是討論如何實現自增id。如果能夠使用redis該問題能夠得到妥善解決,因為redis是單線程的,且提供原子的incrAndGet()命令INCR和原子的getAndSet()命令GETSET。

相關文章:
主站蜘蛛池模板: 电白县| 黑河市| 大新县| 乐业县| 南部县| 合江县| 抚松县| 恩施市| 罗源县| 东阳市| 若羌县| 佛冈县| 沂源县| 托里县| 璧山县| 郯城县| 区。| 淮南市| 翁源县| 建昌县| 上思县| 兴海县| 班玛县| 波密县| 若羌县| 徐水县| 肥乡县| 延庆县| 军事| 攀枝花市| 财经| 阿勒泰市| 青阳县| 兴山县| 梨树县| 张家口市| 政和县| 金平| 泰宁县| 治县。| 高雄市|