MySql 更新時返回主鍵id
來源:程序員人生 發布時間:2015-02-26 21:01:37 閱讀次數:5929次
最近做項目,遇到1個邏輯,就是在修改單條記錄時需要返回該記錄的id。
先說1下我的使用環境,springMVC+MyBatis,因而上度娘查了1下,將結果記錄1下,僅供往后參考和大家們共同探討
具體邏輯就是在多個條件下,包括1個嵌套查詢,對1條記錄進行更新,并返回該記錄的主鍵id,在這個查詢語句里面用到1個變量update_id在履行更新語句的時候將本記錄的id重新賦值為本身的id,同時將本身的id賦值給updatge_id這個變量,最后返回這個變量,就是這個更新最后的目的。
SET @update_id := 0;
UPDATE activity_prize_voucher apv
SET apv.mobile = 18888888888,
apv.state = 1,
apv.exchange_time = NOW(),
apv.id =(SELECT @update_id := id)
WHERE
apv.prize_id = 2
AND apv.state = 0
AND mobile IS NULL
AND exchange_time IS NULL
<span style="color:#ff0000;">AND(
SELECT
vv.exchangeCount <= 2000
FROM
(
SELECT
COUNT(*)AS exchangeCount
FROM
activity_prize_voucher apvv
WHERE
apvv.prize_id = 2
AND apvv.state = 1
AND DATE_FORMAT(NOW(), '%Y%m%d')= DATE_FORMAT( apvv.exchange_time, '%Y%m%d' )
)AS vv
)</span>
LIMIT 1;
SELECT
@update_id;
在 Mapper.xml內的標簽使用為select標簽
<select id="exchangeVoucher" parameterType="hashmap" resultType="java.lang.Integer">
SQL
</select>
在java Dao內方法為:
int exchangeVoucher(Map<String, Object> queryParams);
就這么簡單,這個功能就初步完成,下面對這個邏輯進行優化調劑
=================分割線=========================
好,在華麗麗的分割線下面我們在討論1下上面那段sql里面紅色彩的,在MySQL里面如果要在upadte和delete里面用嵌套查詢1般是不行的,但是如果你將這個嵌套查詢AS為1個對象,然后在對這個對象進行查詢應當就能夠了。
但是,在這里MySQL鎖定WHERE條件掃描過的所有索引記錄,在高并發的時候就會致使紅色語句出現死鎖現象,那末問題來了,如何控制紅色字體的條件,由于紅色區域內的語句只是用來統計1定條件下的數量的,所以只能通過代碼邏輯進行獨立控制。
最后將紅色字體代碼舍去,在履行更新語句之前進行邏輯判斷來控制。
如果哪位達人有更好的方法,希望給我反饋,謝謝。我這里只是拋磚引玉。
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈