最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
索引怎么加入mysql 索引應(yīng)該怎么建

MySQL如何為表字段添加索引

1.添加PRIMARY KEY(主鍵索引):

超過(guò)十余年行業(yè)經(jīng)驗(yàn),技術(shù)領(lǐng)先,服務(wù)至上的經(jīng)營(yíng)模式,全靠網(wǎng)絡(luò)和口碑獲得客戶,為自己降低成本,也就是為客戶降低成本。到目前業(yè)務(wù)范圍包括了:成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作,成都網(wǎng)站推廣,成都網(wǎng)站優(yōu)化,整體網(wǎng)絡(luò)托管,重慶小程序開(kāi)發(fā),微信開(kāi)發(fā),重慶App定制開(kāi)發(fā),同時(shí)也可以讓客戶的網(wǎng)站和網(wǎng)絡(luò)營(yíng)銷和我們一樣獲得訂單和生意!

2.添加UNIQUE(唯一索引) :

3.添加INDEX(普通索引) :

4.添加FULLTEXT(全文索引) :

5.添加多列索引:

MYSQL創(chuàng)建表的時(shí)候如果加 索引

兄弟,primary key是主鍵,每個(gè)表只能有一個(gè)主鍵,而且數(shù)據(jù)是唯一的。\x0d\x0a可以這樣寫:\x0d\x0aCREATE TABLE IF NOT EXISTS `".$ctb_name."` (\x0d\x0a `id` INT(9) NOT NULL AUTO_INCREMENT PRIMARY KEY,\x0d\x0a `keyid` VARCHAR(20) NOT NULL,\x0d\x0a `key` VARCHAR(20) NOT NULL,\x0d\x0a `stauts` BOOL NOT NULL DEFAULT'0',\x0d\x0aindex `idx_status`(`status`)\x0d\x0a )ENGINE = MYISAM DEFAULT CHARSET=utf8;\x0d\x0a不過(guò),status是bool類型的字段,只有true和false,區(qū)分度太低,沒(méi)有必要加索引。\x0d\x0a\x0d\x0a索引目的是為了使查詢更快,區(qū)分度小的時(shí)候不如全表掃描。

Mysql大表加索引

select (*) from tb_name where create_time xxx;

最終得知是因?yàn)檫@個(gè)表數(shù)據(jù)行數(shù)已經(jīng)超過(guò) 一千萬(wàn)了,然后create_time字段又沒(méi)有索引 。

那解決辦法肯定是加索引嘍。

但是這個(gè)表是一直在線上運(yùn)行,很重要和業(yè)務(wù)部分。如果給千萬(wàn)級(jí)的大表在線加索引 ,肯定會(huì)卡死。

然后就搜羅了一大筐解決方案,比如 在線無(wú)鎖加索引使用

ALTER TABLE tbl_name ADD PRIMARY (column), ALGORITHM=INPLACE, LOCK=NONE;

后來(lái)才發(fā)現(xiàn),這個(gè)特性是 Mysql 5.6 以后才支持,然而我們的mysql用的是5.5版本

最后在 《高性能Mysql》一書中看到,可在通過(guò) “影子拷貝”來(lái)解決,

就是 先創(chuàng)建一張和源表無(wú)關(guān)的新表,然后通過(guò)重命名和刪表操作交換兩張表;

當(dāng)給新表加完索引后,最上面那條查詢直接就是0.0002s

場(chǎng)景:在給一張有幾萬(wàn)條記錄的表添加索引時(shí),進(jìn)度非常慢,導(dǎo)致其它查詢無(wú)法進(jìn)行

處理方式:

使用Navicat的命令行模式,執(zhí)行以下命令:

show processlist;

這時(shí)會(huì)看到有哪些線程正在執(zhí)行,也可以查看鎖表的線程。你會(huì)發(fā)現(xiàn)alter table * add key ****那個(gè)線程狀態(tài)是Waiting for table metadata lock,后面有個(gè)這個(gè)表的所有操作都是這個(gè)狀態(tài),很明顯是這條加索引的語(yǔ)句把表給鎖了。

查看線程ID,執(zhí)行

kill 線程ID

這樣被鎖住的表就能立即被使用了。

由此得出一個(gè)結(jié)論,當(dāng)一張表數(shù)據(jù)量很大時(shí),不要輕易添加索引,會(huì)導(dǎo)致表被鎖死!如果非要添加,那么應(yīng)該先把數(shù)據(jù)表進(jìn)行備份,然后進(jìn)行空表添加索引。

只能通過(guò)ALTER TABLE不能create index

參數(shù)說(shuō)明:


文章名稱:索引怎么加入mysql 索引應(yīng)該怎么建
分享地址:http://fisionsoft.com.cn/article/hishph.html