您好,MySQL高并發(fā)添加列的方法有多種,主要有以下幾種:
從網(wǎng)站建設(shè)到定制行業(yè)解決方案,為提供成都做網(wǎng)站、成都網(wǎng)站建設(shè)服務(wù)體系,各種行業(yè)企業(yè)客戶提供網(wǎng)站建設(shè)解決方案,助力業(yè)務(wù)快速發(fā)展。創(chuàng)新互聯(lián)將不斷加快創(chuàng)新步伐,提供優(yōu)質(zhì)的建站服務(wù)。
1. 使用ALTER TABLE語句:使用ALTER TABLE語句可以在表中添加新的列,可以在表中添加多個(gè)列,也可以在表中添加多個(gè)列,但是在高并發(fā)的情況下,這種方法可能會導(dǎo)致表鎖,影響性能。
2. 使用CREATE TABLE語句:使用CREATE TABLE語句可以在表中添加新的列,可以在表中添加多個(gè)列,這種方法可以避免表鎖,但是在高并發(fā)的情況下,可能會導(dǎo)致數(shù)據(jù)不一致,所以不推薦使用。
3. 使用INSERT INTO語句:使用INSERT INTO語句可以在表中添加新的列,可以在表中添加多個(gè)列,這種方法可以避免表鎖,也可以保證數(shù)據(jù)的一致性,但是在高并發(fā)的情況下,可能會導(dǎo)致性能下降,所以也不推薦使用。
4. 使用存儲過程:使用存儲過程可以在表中添加新的列,可以在表中添加多個(gè)列,這種方法可以避免表鎖,也可以保證數(shù)據(jù)的一致性,而且在高并發(fā)的情況下,可以提高性能,所以是比較推薦使用的方法。
限流算法目前程序開發(fā)過程常用的限流算法有兩個(gè):漏桶算法和令牌桶算法。
漏桶算法
漏桶算法的原理比較簡單,請求進(jìn)入到漏桶中,漏桶以一定的速率漏水。當(dāng)請求過多時(shí),水直接溢出。可以看出,漏桶算法可以強(qiáng)制限制數(shù)據(jù)的傳輸速度。如圖所示,把請求比作是水滴,水先滴到桶里,通過漏洞并以限定的速度出水,當(dāng)水來得過猛而出水不夠快時(shí)就會導(dǎo)致水直接溢出,即拒絕服務(wù)。
圖片來自網(wǎng)絡(luò)
漏桶的出水速度是恒定的,那么意味著如果瞬時(shí)大流量的話,將有大部分請求被丟棄掉(也就是所謂的溢出)。
令牌桶算法
令牌桶算法的原理是系統(tǒng)以一定速率向桶中放入令牌,如果有請求時(shí),請求會從桶中取出令牌,如果能取到令牌,則可以繼續(xù)完成請求,否則等待或者拒絕服務(wù)。這種算法可以應(yīng)對突發(fā)程度的請求,因此比漏桶算法好。
圖片來自網(wǎng)絡(luò)
漏桶算法和令牌桶算法的選擇
兩者的主要區(qū)別漏桶算法能夠強(qiáng)行限制處理數(shù)據(jù)的速率,不論系統(tǒng)是否空閑。而令牌桶算法能夠在限制數(shù)據(jù)的平均處理速率的同時(shí)還允許某種程度的突發(fā)流量。如何理解上面的含義呢?漏桶算法,比如系統(tǒng)吞吐量是 120/s,業(yè)務(wù)請求 130/s,使用漏斗限流 100/s,起到限流的作用,多余的請求將產(chǎn)生等待或者丟棄。對于令牌桶算法,每秒產(chǎn)生 100 個(gè)令牌,系統(tǒng)容量 200 個(gè)令牌。正常情況下,業(yè)務(wù)請求 100/s 時(shí),請求能被正常被處理。當(dāng)有突發(fā)流量過來比如 200 個(gè)請求時(shí),因?yàn)橄到y(tǒng)容量有 200 個(gè)令牌可以同一時(shí)刻處理掉這 200 個(gè)請求。如果是漏桶算法,則只能處理 100 個(gè)請求,其他的請求等待或者被丟棄。
具體原因是:
1、索引列值為null,此時(shí)會索引失效。
2、sql的語句中寫了or,如果or后的字段不全是帶索引字段,此時(shí)索引失效。
3、模糊查詢是like以%XX開頭,就是說左模糊不太行,右模糊可以。
4、存在類型轉(zhuǎn)換,比如你的索引字段是varchar型,但是你搜索條件卻是userid=333,那這樣索引不生效。
5、數(shù)據(jù)量極少時(shí),Mysql不會使用索引,因?yàn)槿頀呙杷俣雀臁?/p>
6、where條件中的索引運(yùn)算設(shè)計(jì)計(jì)算時(shí),索引失效。索引列不要使用函數(shù)。