superwei

          導航

          <2006年2月>
          2930311234
          567891011
          12131415161718
          19202122232425
          2627281234
          567891011

          統計

          常用鏈接

          留言簿(4)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          2006年2月22日 #

          希臘字母讀法

          posted @ 2021-06-19 11:43 小辭猬 閱讀(87) | 評論 (0)編輯 收藏

          【Mysql】關于索引

          DB引擎:InnoDB
          兩表A,B表均為6W+的記錄。用B表的信息更新A表。
          SQL:update A left join B on A.field1 = B.field1 and A.field2 = B.field2
                   set A.field3 = B.field3, A.field4 = B.field4
          無引擎時:每1000更新需要2分11秒,全部更新大概需要2~3小時。

          此時加入索引:
          CREATE INDEX field1_Index ON `A`(`field1`);
          注:1、此處只加field1是因為 field2的內容變化很小,就那幾個值。
                2、此SQL里的字段都不是主鍵

          再次執行SQL,效率依舊。似乎索引沒有作用。為了驗證我的想法,查看了執行方式:
          explain update A left join B on A.field1 = B.field1 and A.field2 = B.field2
                   set A.field3 = B.field3, A.field4 = B.field4 
          果然在執行時,沒用到索引。找到癥結,那就繼續找為什么索引沒有被用的原因。
          查找過程省略,直接上結果。
          因為是update,所以我認為 左聯和直聯,對于結果沒有區別,但是從左聯改為直聯后,
          再查詢執行方式,發現就能使用索引(原因暫不知道,以后知道了再寫)
          于是再次執行如下SQL:
          update A inner join B on A.field1 = B.field1 and A.field2 = B.field2
                   set A.field3 = B.field3, A.field4 = B.field4 
          6W+的數據執行時間:1.43秒
          優化完畢。
          另,因為以上字段都非主鍵,所以 SQL修改成以下方式執行似乎更快,查詢執行方式,用到了主鍵索引和我自己加的索引
          update A left join B on A.field1 = B.field1 and A.field2 = B.field2
                   set A.field3 = B.field3, A.field4 = B.field4
          where A.key in (select key from A)

          附:
          刪除索引:drop INDEX field1_Index ON `A`;
          查看索引:show index from A
          查看線程:select * from information_schema.processlist t
                        show processlist
          殺線程: kill processId


          posted @ 2018-10-25 09:49 小辭猬 閱讀(176) | 評論 (0)編輯 收藏

          跳槽 程序員需要注意的十大要點

               摘要: 摘于它處,非我本文  閱讀全文

          posted @ 2007-01-31 21:09 小辭猬 閱讀(422) | 評論 (0)編輯 收藏

          哈哈,新項目開始了

          COBOL的項目就要結束了,下個項目就是.NET.說實在話,我是比較期待,但是如果是C#,我就更加的HAPPY,偏偏要是VB.NET,看了半天,發現怎么就那么的奇怪呢!就感覺看一段沒有斷句的文言文!還好,現在裝了個中文的MSDN,比以前看日文的MSDN要舒服多了,MD,看起來真費勁!

          今天看VB.NET的代碼,突然有種感覺,就像剛到深圳去實習,看人家以前做的項目的代碼一樣,好費勁,很多的關鍵字,咋一看還不知道,稍一迷糊就看到后面,突然發現前面的幾句代碼是啥意思啊!不知道做的時候又是什么樣一種感覺,總的來說就是奇怪!ff

          posted @ 2006-02-22 17:20 小辭猬 閱讀(357) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 仙居县| 丹阳市| 沂南县| 抚顺市| 改则县| 都昌县| 汉源县| 高州市| 仁布县| 余干县| 金阳县| 桐梓县| 武隆县| 兴山县| 崇阳县| 卢氏县| 石门县| 山东省| 赤城县| 托克托县| 苏尼特左旗| 阳朔县| 德州市| 太保市| 鹤山市| 稷山县| 独山县| 太仆寺旗| 罗江县| 高尔夫| 莒南县| 六枝特区| 东宁县| 名山县| 晋州市| 海城市| 厦门市| 寿光市| 孝感市| 远安县| 米易县|