mysql建表索引問題求助
問題描述
小弟建立數(shù)據(jù)表索引遇到幾個(gè)問題,求助下大家:
1.
UPDATE table SET version = 2 WHERE id = ? AND version =?
這個(gè)語句里面id是自增長id,version是樂觀鎖。此時(shí)是應(yīng)該給version建立一個(gè)單獨(dú)索引,還是和id建聯(lián)合索引,還是不需要建索引。
SELECT * FROM table WHERE a in () AND b =? ORDER BY c DESC
in的話應(yīng)該是用不到索引的吧,這個(gè)怎么建?
SELECT * FROM tabler WHERE a = ? AND b > ? AND b < ? ORDER BY c DESC
這個(gè)如何建索引
問題解答
回答1:1.給verson來單獨(dú)索引就行。由於id是主鍵,而且唯一,所以索引效率其實(shí)最高。2.in是可以開啟索引,但是當(dāng)in達(dá)到一定數(shù)量,所以可能會(huì)失效3.a b單獨(dú)做索引。或者 a和b做聯(lián)合索引
回答2:一般情況下單獨(dú)給id字段創(chuàng)建索引就可以了。如果根據(jù)業(yè)務(wù)場景,能預(yù)計(jì)到每個(gè)id的修改次數(shù)非常多,可以把id,version創(chuàng)建聯(lián)合索引。
相關(guān)文章:
1. css - 新手做響應(yīng)式布局, 斷點(diǎn)過后右側(cè)出現(xiàn)空白,求幫助,謝謝。2. python - 啟動(dòng)Eric6時(shí)報(bào)錯(cuò):’qscintilla_zh_CN’ could not be loaded3. javascript - vue 怎么渲染自定義組件4. javascript - 關(guān)于<a>元素與<input>元素的JS事件運(yùn)行問題5. mysql - 查詢字段做了索引為什么不起效,還有查詢一個(gè)月的時(shí)候數(shù)據(jù)都是全部出來的,如果分拆3次的話就沒問題,為什么呢。6. mysql - 記得以前在哪里看過一個(gè)估算時(shí)間的網(wǎng)站7. 大家好,我想請(qǐng)問一下怎么做搜索欄能夠搜索到自己網(wǎng)站的內(nèi)容。8. ID主鍵不是自增的嗎 為什么還要加null9. MySQL中的enum類型有什么優(yōu)點(diǎn)?10. python - 安裝pyspider時(shí)出錯(cuò):No space left on device:
