中文字幕人妻中文_99精品欧美一区二区三区综合在线_精品久久久久一区二区_色月丁香_免费福利在线视频_欧美大片免费观看网址_国产伦精品一区二区三区在线播放_污污污污污污www网站免费_久久月本道色综合久久_色69激情爱久久_尹人香蕉久久99天天拍_国产美女www_亚洲国产精品无码7777一线_五月婷婷六月激情_看免费一级片_精品久久久久久成人av_在线色亚洲_女人另类性混交zo_国产精品青青在线观看爽香蕉_人人澡人人添人人爽一区二区

主頁 > 知識庫 > Mysql使用索引的正確方法及索引原理詳解

Mysql使用索引的正確方法及索引原理詳解

熱門標簽:合肥營銷外呼系統收費 地圖標注賺錢真假 外呼系統從哪買 德惠市地圖標注 陜西400電話如何申請 承德電腦地圖標注 深圳 遵義地圖標注app 商家地圖標注哪個好

一 、介紹

為何要有索引?

一般的應用系統,讀寫比例在10:1左右,而且插入操作和一般的更新操作很少出現性能問題,在生產環境中,我們遇到最多的,也是最容易出問題的,還是一些復雜的查詢操作,因此對查詢語句的優化顯然是重中之重。說起加速查詢,就不得不提到索引了。

什么是索引?

索引在MySQL中也叫做“鍵”,是存儲引擎用于快速找到記錄的一種數據結構。索引對于良好的性能

非常關鍵,尤其是當表中的數據量越來越大時,索引對于性能的影響愈發重要。

索引優化應該是對查詢性能優化最有效的手段了。索引能夠輕易將查詢性能提高好幾個數量級。

索引相當于字典的音序表,如果要查某個字,如果不使用音序表,則需要從幾百頁中逐頁去查。

 30

 10 40

 5 15 35 66

1 6 11 19 21 39 55 100

你是否對索引存在誤解?

索引是應用程序設計和開發的一個重要方面。若索引太多,應用程序的性能可能會受到影響。而索引太少,對查詢性能又會產生影響,要找到一個平衡點,這對應用程序的性能至關重要。一些開發人員總是在事后才想起添加索引----我一直認為,這源于一種錯誤的開發模式。如果知道數據的使用,從一開始就應該在需要處添加索引。開發人員往往對數據庫的使用停留在應用的層面,比如編寫SQL語句、存儲過程之類,他們甚至可能不知道索引的存在,或認為事后讓相關DBA加上即可。DBA往往不夠了解業務的數據流,而添加索引需要通過監控大量的SQL語句進而從中找到問題,這個步驟所需的時間肯定是遠大于初始添加索引所需的時間,并且可能會遺漏一部分的索引。當然索引也并不是越多越好,我曾經遇到過這樣一個問題:某臺MySQL服務器iostat顯示磁盤使用率一直處于100%,經過分析后發現是由于開發人員添加了太多的索引,在刪除一些不必要的索引之后,磁盤使用率馬上下降為20%。可見索引的添加也是非常有技術含量的。

二 、索引的原理

一 、索引原理

索引的目的在于提高查詢效率,與我們查閱圖書所用的目錄是一個道理:先定位到章,然后定位到該章下的一個小節,然后找到頁數。相似的例子還有:查字典,查火車車次,飛機航班等

本質都是:通過不斷地縮小想要獲取數據的范圍來篩選出最終想要的結果,同時把隨機的事件變成順序的事件,也就是說,有了這種索引機制,我們可以總是用同一種查找方式來鎖定數據。

數據庫也是一樣,但顯然要復雜的多,因為不僅面臨著等值查詢,還有范圍查詢(>、、between、in)、模糊查詢(like)、并集查詢(or)等等。數據庫應該選擇怎么樣的方式來應對所有的問題呢?我們回想字典的例子,能不能把數據分成段,然后分段查詢呢?最簡單的如果1000條數據,1到100分成第一段,101到200分成第二段,201到300分成第三段......這樣查第250條數據,只要找第三段就可以了,一下子去除了90%的無效數據。但如果是1千萬的記錄呢,分成幾段比較好?稍有算法基礎的同學會想到搜索樹,其平均復雜度是lgN,具有不錯的查詢性能。但這里我們忽略了一個關鍵的問題,復雜度模型是基于每次相同的操作成本來考慮的。而數據庫實現比較復雜,一方面數據是保存在磁盤上的,另外一方面為了提高性能,每次又可以把部分數據讀入內存來計算,因為我們知道訪問磁盤的成本大概是訪問內存的十萬倍左右,所以簡單的搜索樹難以滿足復雜的應用場景。

二 、磁盤IO與預讀

前面提到了訪問磁盤,那么這里先簡單介紹一下磁盤IO和預讀,磁盤讀取數據靠的是機械運動,每次讀取數據花費的時間可以分為尋道時間、旋轉延遲、傳輸時間三個部分,尋道時間指的是磁臂移動到指定磁道所需要的時間,主流磁盤一般在5ms以下;旋轉延遲就是我們經常聽說的磁盤轉速,比如一個磁盤7200轉,表示每分鐘能轉7200次,也就是說1秒鐘能轉120次,旋轉延遲就是1/120/2 = 4.17ms;傳輸時間指的是從磁盤讀出或將數據寫入磁盤的時間,一般在零點幾毫秒,相對于前兩個時間可以忽略不計。那么訪問一次磁盤的時間,即一次磁盤IO的時間約等于5+4.17 = 9ms左右,聽起來還挺不錯的,但要知道一臺500 -MIPS(Million Instructions Per Second)的機器每秒可以執行5億條指令,因為指令依靠的是電的性質,換句話說執行一次IO的時間可以執行約450萬條指令,數據庫動輒十萬百萬乃至千萬級數據,每次9毫秒的時間,顯然是個災難。下圖是計算機硬件延遲的對比圖,供大家參考:

考慮到磁盤IO是非常高昂的操作,計算機操作系統做了一些優化,當一次IO時,不光把當前磁盤地址的數據,而是把相鄰的數據也都讀取到內存緩沖區內,因為局部預讀性原理告訴我們,當計算機訪問一個地址的數據的時候,與其相鄰的數據也會很快被訪問到。每一次IO讀取的數據我們稱之為一頁(page)。具體一頁有多大數據跟操作系統有關,一般為4k或8k,也就是我們讀取一頁內的數據時候,實際上才發生了一次IO,這個理論對于索引的數據結構設計非常有幫助。

三 、索引的數據結構

前面講了索引的基本原理,數據庫的復雜性,又講了操作系統的相關知識,目的就是讓大家了解,任何一種數據結構都不是憑空產生的,一定會有它的背景和使用場景,我們現在總結一下,我們需要這種數據結構能夠做些什么,其實很簡單,那就是:每次查找數據時把磁盤IO次數控制在一個很小的數量級,最好是常數數量級。那么我們就想到如果一個高度可控的多路搜索樹是否能滿足需求呢?就這樣,b+樹應運而生(B+樹是通過二叉查找樹,再由平衡二叉樹,B樹演化而來)。

如上圖,是一顆b+樹,關于b+樹的定義可以參見B+樹,這里只說一些重點,淺藍色的塊我們稱之為一個磁盤塊,可以看到每個磁盤塊包含幾個數據項(深藍色所示)和指針(黃色所示),如磁盤塊1包含數據項17和35,包含指針P1、P2、P3,P1表示小于17的磁盤塊,P2表示在17和35之間的磁盤塊,P3表示大于35的磁盤塊。真實的數據存在于葉子節點即3、5、9、10、13、15、28、29、36、60、75、79、90、99。非葉子節點只不存儲真實的數據,只存儲指引搜索方向的數據項,如17、35并不真實存在于數據表中。

###b+樹的查找過程

如圖所示,如果要查找數據項29,那么首先會把磁盤塊1由磁盤加載到內存,此時發生一次IO,在內存中用二分查找確定29在17和35之間,鎖定磁盤塊1的P2指針,內存時間因為非常短(相比磁盤的IO)可以忽略不計,通過磁盤塊1的P2指針的磁盤地址把磁盤塊3由磁盤加載到內存,發生第二次IO,29在26和30之間,鎖定磁盤塊3的P2指針,通過指針加載磁盤塊8到內存,發生第三次IO,同時內存中做二分查找找到29,結束查詢,總計三次IO。真實的情況是,3層的b+樹可以表示上百萬的數據,如果上百萬的數據查找只需要三次IO,性能提高將是巨大的,如果沒有索引,每個數據項都要發生一次IO,那么總共需要百萬次的IO,顯然成本非常非常高。

###b+樹性質

1.索引字段要盡量的小:通過上面的分析,我們知道IO次數取決于b+數的高度h,假設當前數據表的數據為N,每個磁盤塊的數據項的數量是m,則有h=㏒(m+1)N,當數據量N一定的情況下,m越大,h越小;而m = 磁盤塊的大小 / 數據項的大小,磁盤塊的大小也就是一個數據頁的大小,是固定的,如果數據項占的空間越小,數據項的數量越多,樹的高度越低。這就是為什么每個數據項,即索引字段要盡量的小,比如int占4字節,要比bigint8字節少一半。這也是為什么b+樹要求把真實的數據放到葉子節點而不是內層節點,一旦放到內層節點,磁盤塊的數據項會大幅度下降,導致樹增高。當數據項等于1時將會退化成線性表。

2.索引的最左匹配特性:當b+樹的數據項是復合的數據結構,比如(name,age,sex)的時候,b+數是按照從左到右的順序來建立搜索樹的,比如當(張三,20,F)這樣的數據來檢索的時候,b+樹會優先比較name來確定下一步的所搜方向,如果name相同再依次比較age和sex,最后得到檢索的數據;但當(20,F)這樣的沒有name的數據來的時候,b+樹就不知道下一步該查哪個節點,因為建立搜索樹的時候name就是第一個比較因子,必須要先根據name來搜索才能知道下一步去哪里查詢。比如當(張三,F)這樣的數據來檢索時,b+樹可以用name來指定搜索方向,但下一個字段age的缺失,所以只能把名字等于張三的數據都找到,然后再匹配性別是F的數據了, 這個是非常重要的性質,即索引的最左匹配特性。

四 、聚集索引與輔助索引

在數據庫中,B+樹的高度一般都在2~4層,這也就是說查找某一個鍵值的行記錄時最多只需要2到4次IO,這倒不錯。因為當前一般的機械硬盤每秒至少可以做100次IO,2~4次的IO意味著查詢時間只需要0.02~0.04秒。

數據庫中的B+樹索引可以分為聚集索引(clustered index)和輔助索引(secondary index),

聚集索引與輔助索引相同的是:不管是聚集索引還是輔助索引,其內部都是B+樹的形式,即高度是平衡的,葉子結點存放著所有的數據。

聚集索引與輔助索引不同的是:葉子結點存放的是否是一整行的信息

1、聚集索引

#InnoDB存儲引擎表示索引組織表,即表中數據按照主鍵順序存放。而聚集索引(clustered index)就是按照每張表的主鍵構造一棵B+樹,同時葉子結點存放的即為整張表的行記錄數據,也將聚集索引的葉子結點稱為數據頁。聚集索引的這個特性決定了索引組織表中數據也是索引的一部分。

同B+樹數據結構一樣,每個數據頁都通過一個雙向鏈表來進行鏈接。 #如果未定義主鍵,MySQL取第一個唯一索引(unique)而且只含非空列(NOT NULL)作為主鍵,InnoDB使用它作為聚簇索引。 #如果沒有這樣的列,InnoDB就自己產生一個這樣的ID值,它有六個字節,而且是隱藏的,使其作為聚簇索引。#由于實際的數據頁只能按照一棵B+樹進行排序,因此每張表只能擁有一個聚集索引。在多少情況下,查詢優化器傾向于采用聚集索引。

因為聚集索引能夠在B+樹索引的葉子節點上直接找到數據。此外由于定義了數據的邏輯順序,聚集索引能夠特別快地訪問針對范圍值得查詢。

聚集索引的好處之一:它對主鍵的排序查找和范圍查找速度非常快,葉子節點的數據就是用戶所要查詢的數據。如用戶需要查找一張表,查詢最后的10位用戶信息,由于B+樹索引是雙向鏈表,所以用戶可以快速找到最后一個數據頁,并取出10條記錄

聚集索引的好處之二:范圍查詢(range query),即如果要查找主鍵某一范圍內的數據,通過葉子節點的上層中間節點就可以得到頁的范圍,之后直接讀取數據頁即可

2、輔助索引

表中除了聚集索引外其他索引都是輔助索引(Secondary Index,也稱為非聚集索引),與聚集索引的區別是:輔助索引的葉子節點不包含行記錄的全部數據。

葉子節點除了包含鍵值以外,每個葉子節點中的索引行中還包含一個書簽(bookmark)。該書簽用來告訴InnoDB存儲引擎去哪里可以找到與索引相對應的行數據。

由于InnoDB存儲引擎是索引組織表,因此InnoDB存儲引擎的輔助索引的書簽就是相應行數據的聚集索引鍵。如下圖

輔助索引的存在并不影響數據在聚集索引中的組織,因此每張表上可以有多個輔助索引,但只能有一個聚集索引。當通過輔助索引來尋找數據時,InnoDB存儲引擎會遍歷輔助索引并通過葉子級別的指針獲得只想主鍵索引的主鍵,然后再通過主鍵索引來找到一個完整的行記錄。

舉例來說,如果在一棵高度為3的輔助索引樹種查找數據,那需要對這個輔助索引樹遍歷3次找到指定主鍵,如果聚集索引樹的高度同樣為3,那么還需要對聚集索引樹進行3次查找,最終找到一個完整的行數據所在的頁,因此一共需要6次邏輯IO訪問才能得到最終的一個數據頁。

五 、MySQL索引管理

一 、功能

1. 索引的功能就是加速查找

2. mysql中的primary key,unique,聯合唯一也都是索引,這些索引除了加速查找以外,還有約束的功能

二 、MySQL常用的索引

普通索引INDEX:加速查找

唯一索引: -主鍵索引PRIMARY KEY:加速查找+約束(不為空、不能重復) -唯一索引UNIQUE:加速查找+約束(不能重復)

聯合索引: -PRIMARY KEY(id,name):聯合主鍵索引 -UNIQUE(id,name):聯合唯一索引 -INDEX(id,name):聯合普通索引

三 、索引的兩大類型hash與btree

#我們可以在創建上述索引的時候,為其指定索引類型,分兩類
hash類型的索引:查詢單條快,范圍查詢慢
btree類型的索引:b+樹,層數越多,數據量指數級增長(我們就用它,因為innodb默認支持它)

#不同的存儲引擎支持的索引類型也不一樣
InnoDB 支持事務,支持行級別鎖定,支持 B-tree、Full-text 等索引,不支持 Hash 索引;
MyISAM 不支持事務,支持表級別鎖定,支持 B-tree、Full-text 等索引,不支持 Hash 索引;
Memory 不支持事務,支持表級別鎖定,支持 B-tree、Hash 等索引,不支持 Full-text 索引;
NDB 支持事務,支持行級別鎖定,支持 Hash 索引,不支持 B-tree、Full-text 等索引;
Archive 不支持事務,支持表級別鎖定,不支持 B-tree、Hash、Full-text 等索引;

四 、創建/刪除索引的語法

#方法一:創建表時
   CREATE TABLE 表名 (
 字段名1 數據類型 [完整性約束條件…],
 字段名2 數據類型 [完整性約束條件…],
 [UNIQUE | FULLTEXT | SPATIAL ] INDEX | KEY
 [索引名] (字段名[(長度)] [ASC |DESC]) 
 );


#方法二:CREATE在已存在的表上創建索引
 CREATE [UNIQUE | FULLTEXT | SPATIAL ] INDEX 索引名 
 ON 表名 (字段名[(長度)] [ASC |DESC]) ;


#方法三:ALTER TABLE在已存在的表上創建索引
 ALTER TABLE 表名 ADD [UNIQUE | FULLTEXT | SPATIAL ] INDEX
 索引名 (字段名[(長度)] [ASC |DESC]) ;
 
#刪除索引:DROP INDEX 索引名 ON 表名字;
#方式一
create table t1(
 id int,
 name char,
 age int,
 sex enum('male','female'),
 unique key uni_id(id),
 index ix_name(name) #index沒有key
);


#方式二
create index ix_age on t1(age);

#方式三
alter table t1 add index ix_sex(sex);

#查看
mysql> show create table t1;
| t1 | CREATE TABLE `t1` (
 `id` int(11) DEFAULT NULL,
 `name` char(1) DEFAULT NULL,
 `age` int(11) DEFAULT NULL,
 `sex` enum('male','female') DEFAULT NULL,
 UNIQUE KEY `uni_id` (`id`),
 KEY `ix_name` (`name`),
 KEY `ix_age` (`age`),
 KEY `ix_sex` (`sex`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1

六 、測試索引

一 、準備

#1. 準備表
create table s1(
id int,
name varchar(20),
gender char(6),
email varchar(50)
);

#2. 創建存儲過程,實現批量插入記錄
delimiter $$ #聲明存儲過程的結束符號為$$
create procedure auto_insert1()
BEGIN
 declare i int default 1;
 while(i3000000)do
 insert into s1 values(i,'duoduo','male',concat('duoduo',i,'@oldboy'));
 set i=i+1;
 end while;
END$$ #$$結束
delimiter ; #重新聲明分號為結束符號

#3. 查看存儲過程
show create procedure auto_insert1\G 

#4. 調用存儲過程
call auto_insert1();

#等到時間長短,看機器性能

提示:創建表的時間長短,看機器的性能,請耐心等待!

二 、在沒有索引的前提下測試查詢速度

#無索引:mysql根本就不知道到底是否存在id等于333333333的記錄,只能把數據表從頭到尾掃描一遍,此時有多少個磁盤塊就需要進行多少IO操作,所以查詢速度很慢
mysql> select * from s1 where id=333333333;
Empty set (0.33 sec)

三 、在表中已經存在大量數據的前提下,為某個字段段建立索引,建立速度會很慢

四 、在索引建立完畢后,以該字段為查詢條件時,查詢速度提升明顯

PS:

1. mysql先去索引表里根據b+樹的搜索原理很快搜索到id等于333333333的記錄不存在,IO大大降低,因而速度明顯提升

2. 我們可以去mysql的data目錄下找到該表,可以看到占用的硬盤空間多了

3. 需要注意,如下圖

五 、總結

#1. 一定是為搜索條件的字段創建索引,比如select * from s1 where id = 333;就需要為id加上索引

#2. 在表中已經有大量數據的情況下,建索引會很慢,且占用硬盤空間,建完后查詢速度加快
比如create index idx on s1(id);會掃描表中所有的數據,然后以id為數據項,創建索引結構,存放于硬盤的表中。
建完以后,再查詢就會很快了。

#3. 需要注意的是:innodb表的索引會存放于s1.ibd文件中,而myisam表的索引則會有單獨的索引文件table1.MYI

MySAM索引文件和數據文件是分離的,索引文件僅保存數據記錄的地址。
而在innodb中,表數據文件本身就是按照B+Tree(BTree即Balance True)組織的一個索引結構,這棵樹的葉節點data域保存了完整的數據記錄。
這個索引的key是數據表的主鍵,因此innodb表數據文件本身就是主索引。
因為inndob的數據文件要按照主鍵聚集,所以innodb要求表必須要有主鍵(Myisam可以沒有),
如果沒有顯式定義,則mysql系統會自動選擇一個可以唯一標識數據記錄的列作為主鍵,
如果不存在這種列,則mysql會自動為innodb表生成一個隱含字段作為主鍵,這字段的長度為6個字節,類型為長整型.

七 、正確使用索引

一 、索引未命中

并不是說我們創建了索引就一定會加快查詢速度,若想利用索引達到預想的提高查詢速度的效果,我們在添加索引時,必須遵循以下問題

1 、范圍問題,或者說條件不明確,條件中出現這些符號或關鍵字:>、>=、、=、!= 、between...and...、like、

大于號、小于號

不等于!=

between ...and...

like

2盡量選擇區分度高的列作為索引,區分度的公式是count(distinct col)/count(*),表示字段不重復的比例,比例越大我們掃描的記錄數越少,唯一鍵的區分度是1,而一些狀態、性別字段可能在大數據面前區分度就是0,那可能有人會問,這個比例有什么經驗值嗎?使用場景不同,這個值也很難確定,一般需要join的字段我們都要求是0.1以上,即平均1條掃描10條記錄

#先把表中的索引都刪除,讓我們專心研究區分度的問題
mysql> desc s1;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id | int(11) | YES | MUL | NULL | |
| name | varchar(20) | YES | | NULL | |
| gender | char(5) | YES | | NULL | |
| email | varchar(50) | YES | MUL | NULL | |
+--------+-------------+------+-----+---------+-------+
rows in set (0.00 sec)

mysql> drop index a on s1;
Query OK, 0 rows affected (0.20 sec)
Records: 0 Duplicates: 0 Warnings: 0

mysql> drop index d on s1;
Query OK, 0 rows affected (0.18 sec)
Records: 0 Duplicates: 0 Warnings: 0

mysql> desc s1;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| name | varchar(20) | YES | | NULL | |
| gender | char(5) | YES | | NULL | |
| email | varchar(50) | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
rows in set (0.00 sec)

先把表中的索引都刪除,讓我們專心研究區分度的問題

我們編寫存儲過程為表s1批量添加記錄,name字段的值均為duoduo,也就是說name這個字段的區分度很低(gender字段也是一樣的,我們稍后再搭理它)

回憶b+樹的結構,查詢的速度與樹的高度成反比,要想將樹的高低控制的很低,需要保證:在某一層內數據項均是按照從左到右,從小到大的順序依次排開,即左1左2左3...

而對于區分度低的字段,無法找到大小關系,因為值都是相等的,毫無疑問,還想要用b+樹存放這些等值的數據,只能增加樹的高度,字段的區分度越低,則樹的高度越高。極端的情況,索引字段的值都一樣,那么b+樹幾乎成了一根棍。本例中就是這種極端的情況,name字段所有的值均為'duoduo'

#現在我們得出一個結論:為區分度低的字段建立索引,索引樹的高度會很高,然而這具體會帶來什么影響呢???

#1:如果條件是name='xxxx',那么肯定是可以第一時間判斷出'xxxx'是不在索引樹中的(因為樹中所有的值均為'duoduo'),所以查詢速度很快

#2:如果條件正好是name='duoduo',查詢時,我們永遠無法從樹的某個位置得到一個明確的范圍,只能往下找,往下找,往下找。。。這與全表掃描的IO次數沒有多大區別,所以速度很慢

分析

3、 =和in可以亂序,比如a = 1 and b = 2 and c = 3 建立(a,b,c)索引可以任意順序,mysql的查詢優化器會幫你優化成索引可以識別的形式

4、 索引列不能參與計算,保持列“干凈”,比如from_unixtime(create_time) = '2014-05-29'就不能使用到索引,原因很簡單,b+樹中存的都是數據表中的字段值,但進行檢索時,需要把所有元素都應用函數才能比較,顯然成本太大。所以語句應該寫成create_time = unix_timestamp('2014-05-29')

5、 and/or

#1、and與or的邏輯
條件1 and 條件2:所有條件都成立才算成立,但凡要有一個條件不成立則最終結果不成立
條件1 or 條件2:只要有一個條件成立則最終結果就成立

#2、and的工作原理
條件:
a = 10 and b = 'xxx' and c > 3 and d =4
索引:
制作聯合索引(d,a,b,c)
工作原理:
對于連續多個and:mysql會按照聯合索引,從左到右的順序找一個區分度高的索引字段(這樣便可以快速鎖定很小的范圍),加速查詢,即按照d—>a->b->c的順序

#3、or的工作原理
條件:
a = 10 or b = 'xxx' or c > 3 or d =4
索引:
制作聯合索引(d,a,b,c)

工作原理:
對于連續多個or:mysql會按照條件的順序,從左到右依次判斷,即a->b->c->d

在左邊條件成立但是索引字段的區分度低的情況下(name,加速查詢)

6最左前綴匹配原則,非常重要的原則,對于組合索引mysql會一直向右匹配直到遇到范圍查詢(>、、between、like)就停止匹配(指的是范圍大了,有索引速度也慢),比如a = 1 and b = 2 and c > 3 and d = 4 如果建立(a,b,c,d)順序的索引,d是用不到索引的,如果建立(a,b,d,c)的索引則都可以用到,a,b,d的順序可以任意調整。

7、 其他情況

- 使用函數
 select * from tb1 where reverse(email) = 'duoduo';
 
- 類型不一致
 如果列是字符串類型,傳入條件是必須用引號引起來,不然...
 select * from tb1 where email = 999;
 
#排序條件為索引,則select字段必須也是索引字段,否則無法命中
- order by
 select name from s1 order by email desc;
 當根據索引排序時候,select查詢的字段如果不是索引,則速度仍然很慢
 select email from s1 order by email desc;
 特別的:如果對主鍵排序,則還是速度很快:
 select * from tb1 order by nid desc;
 
- 組合索引最左前綴
 如果組合索引為:(name,email)
 name and email -- 命中索引
 name -- 命中索引
 email -- 未命中索引


- count(1)或count(列)代替count(*)在mysql中沒有差別了

- create index xxxx on tb(title(19)) #text類型,必須制定長度

其他注意事項

- 避免使用select *
- count(1)或count(列) 代替 count(*)
- 創建表時盡量時 char 代替 varchar
- 表的字段順序固定長度的字段優先
- 組合索引代替多個單列索引(經常使用多個條件查詢時)
- 盡量使用短索引
- 使用連接(JOIN)來代替子查詢(Sub-Queries)
- 連表時注意條件類型需一致
- 索引散列值(重復少)不適合建索引,例:性別不適合

八、 聯合索引與覆蓋索引

一 、聯合索引

聯合索引時指對表上的多個列合起來做一個索引。聯合索引的創建方法與單個索引的創建方法一樣,不同之處在僅在于有多個索引列,如下

mysql> create table t(
 -> a int,
 -> b int,
 -> primary key(a),
 -> key idx_a_b(a,b)
 -> );
Query OK, 0 rows affected (0.11 sec)

那么何時需要使用聯合索引呢?在討論這個問題之前,先來看一下聯合索引內部的結果。從本質上來說,聯合索引就是一棵B+樹,不同的是聯合索引的鍵值得數量不是1,而是>=2。接著來討論兩個整型列組成的聯合索引,假定兩個鍵值得名稱分別為a、b如圖

可以看到這與我們之前看到的單個鍵的B+樹并沒有什么不同,鍵值都是排序的,通過葉子結點可以邏輯上順序地讀出所有數據,就上面的例子來說,即(1,1),(1,2),(2,1),(2,4),(3,1),(3,2),數據按(a,b)的順序進行了存放。

因此,對于查詢select * from table where a=xxx and b=xxx, 顯然是可以使用(a,b) 這個聯合索引的,對于單個列a的查詢select * from table where a=xxx,也是可以使用(a,b)這個索引的。

但對于b列的查詢select * from table where b=xxx,則不可以使用(a,b) 索引,其實你不難發現原因,葉子節點上b的值為1、2、1、4、1、2顯然不是排序的,因此對于b列的查詢使用不到(a,b) 索引

聯合索引的第二個好處是在第一個鍵相同的情況下,已經對第二個鍵進行了排序處理,例如在很多情況下應用程序都需要查詢某個用戶的購物情況,并按照時間進行排序,最后取出最近三次的購買記錄,這時使用聯合索引可以幫我們避免多一次的排序操作,因為索引本身在葉子節點已經排序了,如下

#===========準備表==============
create table buy_log(
 userid int unsigned not null,
 buy_date date
);

insert into buy_log values
(1,'2009-01-01'),
(2,'2009-01-01'),
(3,'2009-01-01'),
(1,'2009-02-01'),
(3,'2009-02-01'),
(1,'2009-03-01'),
(1,'2009-04-01');

alter table buy_log add key(userid);
alter table buy_log add key(userid,buy_date);

#===========驗證==============
mysql> show create table buy_log;
| buy_log | CREATE TABLE `buy_log` (
 `userid` int(10) unsigned NOT NULL,
 `buy_date` date DEFAULT NULL,
 KEY `userid` (`userid`),
 KEY `userid_2` (`userid`,`buy_date`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |

#可以看到possible_keys在這里有兩個索引可以用,分別是單個索引userid與聯合索引userid_2,但是優化器最終選擇了使用的key是userid因為該索引的葉子節點包含單個鍵值,所以理論上一個頁能存放的記錄應該更多
mysql> explain select * from buy_log where userid=2;
+----+-------------+---------+------+-----------------+--------+---------+-------+------+-------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+---------+------+-----------------+--------+---------+-------+------+-------+
| 1 | SIMPLE | buy_log | ref | userid,userid_2 | userid | 4 | const | 1 | |
+----+-------------+---------+------+-----------------+--------+---------+-------+------+-------+
row in set (0.00 sec)

#接著假定要取出userid為1的最近3次的購買記錄,用的就是聯合索引userid_2了,因為在這個索引中,在userid=1的情況下,buy_date都已經排序好了
mysql> explain select * from buy_log where userid=1 order by buy_date desc limit 3;
+----+-------------+---------+------+-----------------+----------+---------+-------+------+--------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+---------+------+-----------------+----------+---------+-------+------+--------------------------+
| 1 | SIMPLE | buy_log | ref | userid,userid_2 | userid_2 | 4 | const | 4 | Using where; Using index |
+----+-------------+---------+------+-----------------+----------+---------+-------+------+--------------------------+
row in set (0.00 sec)

#ps:如果extra的排序顯示是Using filesort,則意味著在查出數據后需要二次排序


#對于聯合索引(a,b),下述語句可以直接使用該索引,無需二次排序
select ... from table where a=xxx order by b;

#然后對于聯合索引(a,b,c)來首,下列語句同樣可以直接通過索引得到結果
select ... from table where a=xxx order by b;
select ... from table where a=xxx and b=xxx order by c;

#但是對于聯合索引(a,b,c),下列語句不能通過索引直接得到結果,還需要自己執行一次filesort操作,因為索引(a,c)并未排序
select ... from table where a=xxx order by c;

二、 覆蓋索引

InnoDB存儲引擎支持覆蓋索引(covering index,或稱索引覆蓋),即從輔助索引中就可以得到查詢記錄,而不需要查詢聚集索引中的記錄。

使用覆蓋索引的一個好處是:輔助索引不包含整行記錄的所有信息,故其大小要遠小于聚集索引,因此可以減少大量的IO操作

注意:覆蓋索引技術最早是在InnoDB Plugin中完成并實現,這意味著對于InnoDB版本小于1.0的,或者MySQL數據庫版本為5.0以下的,InnoDB存儲引擎不支持覆蓋索引特性

對于InnoDB存儲引擎的輔助索引而言,由于其包含了主鍵信息,因此其葉子節點存放的數據為(primary key1,priamey key2,...,key1,key2,...)。例如

select age from s1 where id=123 and name = 'duoduo'; #id字段有索引,但是name字段沒有索引,該sql命中了索引,但未覆蓋,需要去聚集索引中再查找詳細信息。
最牛逼的情況是,索引字段覆蓋了所有,那全程通過索引來加速查詢以及獲取結果就ok了
mysql> desc s1;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id | int(11) | NO | | NULL | |
| name | varchar(20) | YES | | NULL | |
| gender | char(6) | YES | | NULL | |
| email | varchar(50) | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
rows in set (0.21 sec)

mysql> explain select name from s1 where id=1000; #沒有任何索引
+----+-------------+-------+------------+------+---------------+------+---------+------+---------+----------+-------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+-------+------------+------+---------------+------+---------+------+---------+----------+-------------+
| 1 | SIMPLE | s1 | NULL | ALL | NULL | NULL | NULL | NULL | 2688336 | 10.00 | Using where |
+----+-------------+-------+------------+------+---------------+------+---------+------+---------+----------+-------------+
row in set, 1 warning (0.00 sec)

mysql> create index idx_id on s1(id); #創建索引
Query OK, 0 rows affected (4.16 sec)
Records: 0 Duplicates: 0 Warnings: 0

mysql> explain select name from s1 where id=1000; #命中輔助索引,但是未覆蓋索引,還需要從聚集索引中查找name
+----+-------------+-------+------------+------+---------------+--------+---------+-------+------+----------+-------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+-------+------------+------+---------------+--------+---------+-------+------+----------+-------+
| 1 | SIMPLE | s1 | NULL | ref | idx_id | idx_id | 4 | const | 1 | 100.00 | NULL |
+----+-------------+-------+------------+------+---------------+--------+---------+-------+------+----------+-------+
row in set, 1 warning (0.08 sec)

mysql> explain select id from s1 where id=1000; #在輔助索引中就找到了全部信息,Using index代表覆蓋索引
+----+-------------+-------+------------+------+---------------+--------+---------+-------+------+----------+-------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+-------+------------+------+---------------+--------+---------+-------+------+----------+-------------+
| 1 | SIMPLE | s1 | NULL | ref | idx_id | idx_id | 4 | const | 1 | 100.00 | Using index |
+----+-------------+-------+------------+------+---------------+--------+---------+-------+------+----------+-------------+
row in set, 1 warning (0.03 sec)

覆蓋索引的另外一個好處是對某些統計問題而言的。基于上一小結創建的表buy_log,查詢計劃如下

mysql> explain select count(*) from buy_log;
+----+-------------+---------+-------+---------------+--------+---------+------+------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+---------+-------+---------------+--------+---------+------+------+-------------+
| 1 | SIMPLE | buy_log | index | NULL | userid | 4 | NULL | 7 | Using index |
+----+-------------+---------+-------+---------------+--------+---------+------+------+-------------+
row in set (0.00 sec)

innodb存儲引擎并不會選擇通過查詢聚集索引來進行統計。由于buy_log表有輔助索引,而輔助索引遠小于聚集索引,選擇輔助索引可以減少IO操作,故優化器的選擇如上key為userid輔助索引

對于(a,b)形式的聯合索引,一般是不可以選擇b中所謂的查詢條件。但如果是統計操作,并且是覆蓋索引,則優化器還是會選擇使用該索引,如下

#聯合索引userid_2(userid,buy_date),一般情況,我們按照buy_date是無法使用該索引的,但特殊情況下:查詢語句是統計操作,且是覆蓋索引,則按照buy_date當做查詢條件時,也可以使用該聯合索引
mysql> explain select count(*) from buy_log where buy_date >= '2011-01-01' and buy_date  '2011-02-01';
+----+-------------+---------+-------+---------------+----------+---------+------+------+--------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+---------+-------+---------------+----------+---------+------+------+--------------------------+
| 1 | SIMPLE | buy_log | index | NULL | userid_2 | 8 | NULL | 7 | Using where; Using index |
+----+-------------+---------+-------+---------------+----------+---------+------+------+--------------------------+
row in set (0.00 sec)

九、查詢優化神器-explain

關于explain命令相信大家并不陌生,具體用法和字段含義可以參考官網explain-output,這里需要強調rows是核心指標,絕大部分rows小的語句執行一定很快(有例外,下面會講到)。所以優化語句基本上都是在優化rows。

執行計劃:讓mysql預估執行操作(一般正確)
all index range index_merge ref_or_null ref eq_ref system/const
id,email

慢:
select * from userinfo3 where name='alex'

explain select * from userinfo3 where name='alex'
type: ALL(全表掃描)
select * from userinfo3 limit 1;
快:
select * from userinfo3 where email='alex'
type: const(走索引)

參考文中:https://www.jb51.net/article/140759.htm

十 、慢查詢優化的基本步驟

0.先運行看看是否真的很慢,注意設置SQL_NO_CACHE
1.where條件單表查,鎖定最小返回記錄表。這句話的意思是把查詢語句的where都應用到表中返回的記錄數最小的表開始查起,單表每個字段分別查詢,看哪個字段的區分度最高
2.explain查看執行計劃,是否與1預期一致(從鎖定記錄較少的表開始查詢)
3.order by limit 形式的sql語句讓排序的表優先查
4.了解業務方使用場景
5.加索引時參照建索引的幾大原則
6.觀察結果,不符合預期繼續從0分析

十一、 慢日志管理

慢日志
            - 執行時間 > 10
            - 未命中索引
            - 日志文件路徑
           
        配置:
            - 內存
                show variables like '%query%';
                show variables like '%queries%';
                set global 變量名 = 值
            - 配置文件
                mysqld --defaults-file='E:\wupeiqi\mysql-5.7.16-winx64\mysql-5.7.16-winx64\my-default.ini'
               
                my.conf內容:
                    slow_query_log = ON
                    slow_query_log_file = D:/....
                   
                注意:修改配置文件之后,需要重啟服務

MySQL日志管理

========================================================

錯誤日志: 記錄 MySQL 服務器啟動、關閉及運行錯誤等信息
二進制日志: 又稱binlog日志,以二進制文件的方式記錄數據庫中除 SELECT 以外的操作
查詢日志: 記錄查詢的信息
慢查詢日志: 記錄執行時間超過指定時間的操作
中繼日志: 備庫將主庫的二進制日志復制到自己的中繼日志中,從而在本地進行重放
通用日志: 審計哪個賬號、在哪個時段、做了哪些事件
事務日志或稱redo日志: 記錄Innodb事務相關的如事務執行時間、檢查點等
========================================================

一、bin-log

1. 啟用

# vim /etc/my.cnf
[mysqld]
log-bin[=dir\[filename]]
# service mysqld restart

2. 暫停

//僅當前會話
SET SQL_LOG_BIN=0;
SET SQL_LOG_BIN=1;

3. 查看

查看全部:

# mysqlbinlog mysql.000002
按時間:
# mysqlbinlog mysql.000002 --start-datetime="2012-12-05 10:02:56"
# mysqlbinlog mysql.000002 --stop-datetime="2012-12-05 11:02:54"
# mysqlbinlog mysql.000002 --start-datetime="2012-12-05 10:02:56" --stop-datetime="2012-12-05 11:02:54" 

按字節數:

# mysqlbinlog mysql.000002 --start-position=260
# mysqlbinlog mysql.000002 --stop-position=260
# mysqlbinlog mysql.000002 --start-position=260 --stop-position=930

4. 截斷bin-log(產生新的bin-log文件)

a. 重啟mysql服務器

b. # mysql -uroot -p123 -e 'flush logs'

5. 刪除bin-log文件

# mysql -uroot -p123 -e 'reset master' 

二、查詢日志

啟用通用查詢日志

# vim /etc/my.cnf
[mysqld]
log[=dir\[filename]]
# service mysqld restart

三、慢查詢日志

啟用慢查詢日志

# vim /etc/my.cnf
[mysqld]
log-slow-queries[=dir\[filename]]
long_query_time=n
# service mysqld restart

MySQL 5.6:

slow-query-log=1
slow-query-log-file=slow.log
long_query_time=3

查看慢查詢日志

測試:

BENCHMARK(count,expr)
SELECT BENCHMARK(50000000,2*3);

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • mysql 添加索引 mysql 如何創建索引
  • MySQL查看、創建和刪除索引的方法
  • MySQL 創建索引(Create Index)的方法和語法結構及例子
  • Mysql索引會失效的幾種情況分析
  • MySQL 主鍵與索引的聯系與區別分析
  • 基于mysql全文索引的深入理解
  • mysql性能優化之索引優化
  • MySQL 索引分析和優化
  • Mysql索引類型與基本用法實例分析

標簽:巴中 三門峽 南陽 貴州 商丘 贛州 揚州 新余

巨人網絡通訊聲明:本文標題《Mysql使用索引的正確方法及索引原理詳解》,本文關鍵詞  Mysql,使用,索引,的,正確,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Mysql使用索引的正確方法及索引原理詳解》相關的同類信息!
  • 本頁收集關于Mysql使用索引的正確方法及索引原理詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 纸箱机械设备有限公司| 太原市 机械有限公司| 常州市龙鑫化工机械有限公司 | 珠海机械设备有限公司| 郑州宇机械有限公司| 济宁福康机械加工有限公司| 台州万洲机械有限公司| 江阴精力机械有限公司| 湖北创联重工有限公司| 山东海诺机械有限公司| 天津机械配件有限公司| 青岛昌源隆纺织机械有限公司| 南京登峰起重设备制造有限公司| 广州大圆机械设备有限公司| 济宁四通工程机械有限公司| 杭州龙云水利机械制造有限公司| 天津亨旺机械有限公司| 济南鼎业机械制造有限公司| 立信染整机械深圳有限公司| 河南点赞钢铁有限公司| 上海昱音机械有限公司| 杭州中亚机械 有限公司| 苏州 机械有限公司| 南京腾阳机械有限公司| 江阴市机械制造有限公司| 明辉机械设备制造有限公司| 上海舜锋机械制造有限公司| 张家口煤矿机械有限公司| 北京起重机械有限公司| 北京机械设备有限公司| 柳溪机械设备有限公司| 溧阳科华机械制造有限公司| 厦门市机械有限公司| 深圳市机械设备有限公司| 重庆庆达机械有限公司| 上海启秀机械设备有限公司| 湖北江重机械制造有限公司| 温州华联机械有限公司| 江苏江南起重机械有限公司| 张家港市机械有限公司| 浙江富龙钢铁有限公司| 张家港和和机械有限公司| 广州新浪爱拓化工机械有限公司| 吉林吉钢铁有限公司| 江苏桂铭机械有限公司| 一帆机械设备有限公司| 浙江森工木工机械有限公司| 新乡市豫新起重机械有限公司 | 河南乾坤工程机械有限公司| 浙江机械设备有限公司| 南通振康机械有限公司| 上海派协包装机械有限公司| 佛山星光传动机械有限公司| 天津艾尔特精密机械有限公司| 中山 机械有限公司| 新乡市特昌振动机械有限公司| 咸阳机械制造有限公司| 东莞市途锐机械有限公司| 攀枝花钢铁有限公司| 山东德丰重工有限公司| 太平洋机械有限公司| 星塔机械深圳有限公司| 丹阳市华泰制药机械有限公司| 宝德机械国际有限公司| 郑州同鼎机械设备有限公司| 上海科纳机械有限公司| 苏州艾卓精密机械有限公司| 肥城金塔机械有限公司| 大连塑料机械有限公司| 珠海 机械 有限公司| 景德镇 机械有限公司| 山东浩信机械有限公司| 广州伟乐机械设备有限公司| 深圳市美鹏机械设备有限公司| 上海丁博重工机械有限公司| 浙江临海机械有限公司| 郑州兆明机械有限公司| 山东金大丰机械有限公司| 制药机械设备有限公司| 昆山尚亦精密机械有限公司| 中科包装机械有限公司| 河北大恒重型机械有限公司| 高臻机械设备有限公司| 江苏鑫锋重工机床有限公司| 蚌埠神舟机械有限公司| 河南万泰机械有限公司| 江苏瀚皋机械有限公司| 浙江富龙钢铁有限公司| 首都航天机械有限公司| 宁波力源机械有限公司| 佳友精密机械有限公司| 上海塑帝机械有限公司| 临沂机械制造有限公司| 道依茨法尔机械有限公司| 无锡祥靖机械有限公司| 江西钧天机械有限公司奔驰| 四川欧曼机械有限公司| 南京东部精密机械有限公司| 比富机械(东莞)有限公司| 山东锦坤机械有限公司| 油机机械工业有限公司| 唐盛国际机械有限公司| 河南省新乡市矿山起重机有限公司| 江阴力达机械有限公司| 苏州 机械有限公司| 一帆机械设备有限公司| 三明 机械有限公司| 卓轮天津机械有限公司| 苏州威锐机械有限公司| 南宁敏创机械有限公司| 德阳 机械有限公司| 油机机械工业有限公司| 山东三维重工有限公司| 江苏新益机械有限公司| 上海锐精密机械有限公司| 山西天祥机械有限公司| 青岛顺丰机械有限公司| 重庆阿德耐特动力机械有限公司| 上海方星机械设备制造有限公司| 河北冀工机械制造有限公司| 重庆江峰机械有限公司| 山东起重设备有限公司| 广州机械设备制造有限公司| 华天机械制造有限公司| 广州萱裕机械有限公司| 广东烨辉钢铁有限公司| 吴江聚力机械有限公司| 青岛数控机械有限公司| 广州市市政工程机械施工有限公司| 广东食品机械有限公司| 江苏源德机械有限公司| 上海科劳机械设备有限公司| 山东瑞华机械有限公司| 维美德造纸机械技术有限公司| 昆玉钢铁有限公司招聘| 新疆起亚铝业有限公司招聘| 海宁亚东机械有限公司| 苏州辽鞍机械有限公司| 广州市台展机械有限公司| 江苏福克斯机械有限公司| 承德建龙钢铁有限公司| 苏州牧天动力机械有限公司| 资阳 机械有限公司| 广州精密机械有限公司| 昆成机械(昆山)有限公司| 晋江机械制造有限公司| 无锡传动机械有限公司| 江苏福克斯机械有限公司| 兰州兰石重工有限公司| 江苏羚羊机械有限公司| 福建亿鑫钢铁有限公司| 宁波佳尔灵气动机械有限公司| 广州市 包装机械有限公司| 养殖有限公司起名大全| 广州市日富包装机械有限公司| 福州优利机械有限公司| 山东青州机械有限公司| 广州工友起重设备制造有限公司| 无锡旭辉机械有限公司| 埃比西斯机械有限公司| 浙江五一机械有限公司| 江苏隆达机械设备有限公司| 南牧机械有限公司招聘| 蓬莱万寿机械有限公司| 北京机械施工有限公司| 无锡市机械制造有限公司| 重庆中容石化机械制造有限公司| 邹平 机械有限公司| 宏力机械设备有限公司| 深圳市丹耐斯机械有限公司| 中山市机械有限公司| 青岛顺德塑料机械有限公司| 江门振达机械有限公司| 昆山博通机械设备有限公司| 江苏钢锐精密机械有限公司 | 青岛兴机械有限公司| 攀枝花钢铁有限公司| 上海钢铁贸易有限公司| 环保设备机械有限公司| 沧州机械制造有限公司| 上海紫明印刷机械有限公司| 莱州市龙骏化工机械有限公司| 上海星申机械有限公司| 兖矿大陆机械有限公司| 无锡包装机械有限公司| 禹城通裕新能源机械铸造有限公司| 北仑旭升机械有限公司| 苏州昶智精密机械有限公司| 浙江隆信机械制造有限公司| 浙江四和机械有限公司| 山东机械设备有限公司怎么样| 启益电器材机械有限公司招聘| 上海江埔印刷机械有限公司| 油机机械工业有限公司| 河北澳金机械设备有限公司| 上海辰品食品机械有限公司| 柳州欧维姆机械有限公司| 河南小松工程机械有限公司| 浙江金马逊机械有限公司| 眉山千层弹花机械有限公司| 豫工机械设备有限公司| 粮食机械设备有限公司| 鼎龙机械制造有限公司| 河北中伟机械有限公司| 江苏普格机械有限公司| 射阳 机械有限公司| 上海连富机械有限公司| 新乡市东源机械有限公司| 五矿钢铁上海有限公司| 中机北方机械有限公司| 中核华兴达丰工程机械有限公司| 上海宝峨机械有限公司| 建筑工程有限公司起名| 泰安正阳机械有限公司| 苏州朗威电子机械有限公司| 大连起重矿山机械有限公司| 寿光 机械有限公司| 烟台莫深机械设备有限公司 | 诸城隆泽机械有限公司| 抚顺新钢铁有限公司| 常州天山重工机械有限公司 | 东莞市瑞沧机械设备有限公司| 唐山鑫杭钢铁有限公司| 江苏百事德机械有限公司 | 合肥亿恒机械有限公司| 盐城万富隆机械制造有限公司| 自贡机械制造有限公司| 山东金奥机械有限公司| 徐州福曼随车起重机有限公司 | 山东新船重工有限公司| 东莞市大机械有限公司| 辛集市澳森钢铁有限公司| 东莞共荣精密机械有限公司| 四川开拓建筑机械租赁有限公司| 重庆明天机械有限公司| 福建三宝钢铁有限公司| 杭州大禹机械有限公司| 浙江工程机械有限公司| 浙江名瑞机械有限公司| 浙江欣炜机械有限公司| 佛山三技精密机械有限公司| 兰溪永丰机械有限公司| 浙江东星纺织机械有限公司| 济南龙安机械有限公司| 苏州五金机械有限公司| 湛江市机械有限公司| 杭州中亚机械有限公司| 广东锐亚机械有限公司| 安徽宏远机械制造有限公司 | 东莞市鸿铭机械有限公司| 山东杰卓机械有限公司| 徐州徐工随车起重机有限公司| 威马农业机械有限公司| 上海昊农农业机械有限公司| 东莞机械设备有限公司| 无锡海龙机械有限公司| 顺昌机械制造有限公司| 山东良鑫机械有限公司| 合肥明泰机械施工有限公司| 上海江埔印刷机械有限公司| 石油机械制造有限公司| 湖州机械设备有限公司| 大连滨海起重机吊具有限公司| 天津钢管钢铁贸易有限公司| 宜兴富曦机械有限公司| 山东天元建设机械有限公司| 河南省金特振动机械有限公司| 重庆 机械配件有限公司| 广东龙辉基业建筑机械有限公司 | 杭州同创顶立机械有限公司| 上海利昆机械有限公司| 广西机械设备有限公司| 唐山安丰钢铁有限公司| 霸州新利钢铁有限公司| 广州汇亿机械有限公司| 大连 机械制造有限公司| 高义钢铁有限公司电话| 三联传动机械有限公司| 环保机械设备有限公司| 中石化机械有限公司| 平湖英厚机械有限公司| 泰安重工机械有限公司| 中核华兴达丰机械工程有限公司| 青岛精锐机械制造有限公司| 济南 机械设备有限公司| 宁波市海达塑料机械有限公司| 上海鑫水机械有限公司| 东风悦达起亚有限公司| 唐河大华机械有限公司| 朗维纺织机械有限公司| 广东食品机械有限公司| 无锡建筑机械有限公司| 西安机械设备有限公司| 浙江帅锋精密机械制造有限公司| 洛阳福格森机械装备有限公司| 南京南特精密机械有限公司| 上海卓亚矿山机械有限公司| 徐州徐工随车起重机有限公司| 北京建筑机械有限公司| 厦门洪海机械有限公司| 河北曙光机械有限公司| 全椒 机械有限公司| 三鑫重工机械有限公司| 瑞安瑞泰机械有限公司| 鑫鑫建筑机械有限公司| 茂名重力石化机械制造有限公司| 安徽机械设备有限公司| 杭州杭达机械有限公司| 天津艾尔特精密机械有限公司| 扬州文轩钢铁有限公司| 仕诚塑料机械有限公司| 浙江汉达机械有限公司| 河北小犟牛工程机械有限公司| 宁波环海重工有限公司| 徐工建机机械有限公司| 唐山凯恒钢铁有限公司| 天津宏大纺织机械有限公司| 珠海市机械有限公司| 重庆旺田机械有限公司| 杭州化工机械有限公司| 大连龙尧塑料机械有限公司| 金格瑞机械有限公司| 无锡诺亚机械有限公司| 宁波星箭航天机械有限公司| 广州美特机械有限公司| 武安市文安钢铁有限公司| 佛山钢铁贸易有限公司| 精密机械配件有限公司| 济南天方机械有限公司| 东莞市永创包装机械有限公司| 苏州圣亚精密机械有限公司 | 迅得机械东莞有限公司| 六安恒源机械有限公司| 泰安鑫杰机械有限公司| 广东达诚机械有限公司| 固达机械制造有限公司| 派克包装机械有限公司| 温州市日力轻工机械有限公司| 山西秋林机械有限公司| 济南 机械有限公司| 太仓健柏机械有限公司| 青岛诺恩包装机械有限公司| 厦门国桥机械有限公司| 河北新钢钢铁有限公司| 柳州欧维姆机械有限公司| 厦门天一精密机械有限公司| 上海东蒙路桥机械有限公司 | 浙江中力机械有限公司| 研精舍上海精密机械加工有限公司 | 东莞市数控机械有限公司| 小森机械南通有限公司| 江阴市洪腾机械有限公司| 嘉兴瑞宏精密机械有限公司| 河北燕兴机械有限公司| 山东永峰钢铁有限公司| 重庆机械有限公司招聘| 河北鑫晟机械有限公司| 广州坚诺机械设备有限公司| 瑞安市方泰机械有限公司| 丽驰精密机械有限公司| 温州名瑞机械有限公司| 扬州机械制造有限公司| 青岛青锻锻压机械有限公司 | 海宁美惠机械有限公司| 重庆卡滨通用机械有限公司| 山东建昌机械有限公司| 江阴长达钢铁有限公司| 大方起重机器有限公司| 常州倍安特动力机械有限公司| 常州昊博机械有限公司| 新乡正兴机械有限公司| 制药机械设备有限公司| 唐山榕丰钢铁有限公司| 濮阳市名利石化机械设备制造有限公司| 温州华珍机械有限公司| 青岛精锐机械制造有限公司 | 青岛金福鑫塑料机械有限公司| 东莞仕能机械设备有限公司| 浙江网路崛起有限公司| 利德盛机械有限公司| 中信重工机器人有限公司| 上海昱庄机械有限公司| 河南乾坤工程机械有限公司| 河北敬业钢铁有限公司| 亿传玻璃机械有限公司| 随州市恒大机械铸造有限公司 | 浙江建机起重机械有限公司| 广州益川机械有限公司| 嘉善精密机械有限公司| 广州恒星冷冻机械制造有限公司 | 广东恒联食品机械有限公司| 合肥锦利丰机械有限公司| 福建敏捷机械有限公司| 北京永创通达机械设备有限公司 | 科尼乐机械设备有限公司| 唐山印刷机械有限公司| 广州华劲机械有限公司| 温州奋起皮业有限公司| 潍坊 重工 有限公司| 青岛华牧机械有限公司| 上海天和制药机械有限公司| 宁波美亚特精密机械有限公司| 福建东钢钢铁有限公司| 深圳市奥德机械有限公司| 瑞安市方泰机械有限公司| 苏州铭峰精密机械有限公司 | 苏州荣业机械有限公司| 普特工程机械有限公司| 徐州世通重工机械制造有限公司| 潍坊宝润机械有限公司| 辽阳腾龙钢铁有限公司| 集瑞联合重工有限公司| 洛阳耿力机械有限公司| 深圳固尔琦包装机械有限公司 | 湖南嘉龙机械设备贸易有限公司| 南京利德盛机械有限公司| 深圳格瑞克机械有限公司| 浙江乐江机械有限公司| 杭州定江机械有限公司| 江苏鸡煤机械有限公司| 山东泰山起重机械有限公司| 四川阳光机械有限公司| 鼎龙机械制造有限公司| 广州机械租赁有限公司| 浙江凯岛起重机械有限公司| 华亿机械制造有限公司| 广州凯诺机械有限公司| 山鑫机械制造有限公司| 斗山工程机械苏州有限公司| 枣庄金正钢铁有限公司| 河南世茂机械制造有限公司 | 上海申克机械有限公司| 郑州鑫宇机械制造有限公司| 江阴兴澄特种钢铁有限公司| 宁波环海重工有限公司| 上海钢铁贸易有限公司| 江苏大津重工有限公司| 济南大鹏机械设备有限公司| 博路威机械江苏有限公司| 高密高锻机械有限公司| 山东国新起重机械有限公司| 上海鹰宏机械有限公司| 江西省机械有限公司| 西安冠杰机械设备有限公司| 源田床具机械有限公司| 杭州瑞东机械有限公司| 唐山新宝泰钢铁有限公司| 腾飞机械有限公司地址| 佛山市机械有限公司| 武汉鑫巨力精密机械制造有限公司| 武安市文安钢铁有限公司| 无锡通用机械厂有限公司| 苏州包装机械有限公司| 中信重工机器人有限公司| 上海松精机械制造有限公司| 青岛科尼乐机械设备有限公司 | 广东省重工建筑设计院有限公司 | 江苏迈安德食品机械有限公司| 常州曼恩机械有限公司| 机械加工 有限公司| 东莞市鼎祥通用机械设备有限公司| 常州聚武机械有限公司| 老挝第一钢铁有限公司| 珠海市中鑫隆机械化建设工程有限公司| 华东机械制造有限公司| 郑州市机械设备有限公司| 江苏宏威重工机床制造有限公司| 青岛三益塑料机械有限公司| 河北小松工程机械贸易有限公司| 文穗塑料机械有限公司| 常州化工机械有限公司| 沁阳宏达钢铁有限公司| 江苏润明机械设备有限公司怎么样 | 青岛开牧机械有限公司| 郑州新水工机械有限公司| 运输有限公司起名大全| 广东耐施特机械有限公司| 青州市国发包装机械有限公司 | 杭州纺织机械有限公司| 昆山 机械 有限公司| 新源重工机械有限公司| 临沂三友重工有限公司| 北京航天振邦精密机械有限公司 | 南京巴蜀机械有限公司| 山东兴田机械有限公司| 三一国杰机械有限公司| 常州金源机械设备有限公司| 淮南凯盛重工有限公司| 中机北方机械有限公司| 杭州旭众机械设备有限公司| 合肥福晟机械制造有限公司| 塑料机械 有限公司| 合肥起重机械有限公司| 安徽柳工起重机有限公司| 常州远见机械有限公司| 四川依赛特机械制造有限公司 | 江苏纺织机械有限公司| 重庆华渝重工机电有限公司| 上海丁博重工机械有限公司| 廊坊包装机械有限公司| 宁波延晟机械有限公司| 本源兴(上海)包装机械材料有限公司| 烟台天成机械有限公司| 合肥市春晖机械制造有限公司| 吉林吉钢钢铁有限公司| 大连正丰机械有限公司| 常熟 机械有限公司| 山东华珠机械有限公司| 苏州首达机械有限公司| 上海建冶重工机械有限公司| 济南包装机械械有限公司| 上海天和制药机械有限公司| 昆山环保机械有限公司| 上海 机械制造有限公司| 宁海奇精机械有限公司| 佛山精密机械有限公司| 东莞祥艺机械有限公司| 兰州 机械 有限公司| 浙江青山钢铁有限公司| 上海远跃制药机械有限公司| 无锡 液压机械有限公司| 无锡工程机械有限公司| 群基精密机械有限公司| 新乡市新久振动机械有限公司| 沈阳重工食品有限公司| 河南广泰机械有限公司| 浙江长泰机械有限公司| 上海沛愉机械制造有限公司| 东风悦达起亚有限公司| 广东金凯锐机械技术有限公司| 韶瑞重工有限公司招聘| 徐州荣阳钢铁有限公司| 浙江华安机械有限公司| 句容立成强机械有限公司| 苏州鸿本机械制造有限公司| 河北昭达机械有限公司| 天门纺织机械有限公司| 湖南宇泰重工有限公司| 鞍山机械重工有限公司| 苏州宁兴精密机械有限公司| 上海陵城机械有限公司| 上海宇意机械有限公司| 龙文机械设备有限公司| 西安市机械有限公司| 长沙中传机械有限公司| 陕西金奇机械电器制造有限公司| 徐州川一工程机械有限公司| 台州通宇变速机械有限公司| 苏州金纬机械制造有限公司| 福清市机械有限公司| 常州拓美威精密机械有限公司 | 浙江凯岛起重机械有限公司| 江阴市联拓重工机械有限公司| 山东金奥机械有限公司| 陕西锦泰机械有限公司| 山东重特机械有限公司| 杭州冠浩机械设备有限公司 | 河南信联重工机械有限公司| 东莞市泽源机械有限公司| 广西中源机械有限公司| 沈阳透平机械有限公司| 青岛联瑞精密机械有限公司| 安宁永昌钢铁有限公司| 济宁机械制造有限公司| 青州康达机械有限公司| 苏州乐嘉机械有限公司| 佛山市海裕机械有限公司| 江苏飞耀机械制造有限公司| 临沂盖氏机械有限公司| 山东宝星机械有限公司| 广州轻工机械有限公司| 广州海缔机械有限公司| 深圳 机械设备有限公司| 沧州沧狮磨浆机械有限公司| 安丘博阳机械制造有限公司| 浙江华业塑料机械有限公司| 江苏环海重工有限公司| 山东威曼机械有限公司| 天津华信机械有限公司| 长春机械设备有限公司| 临沂胜代机械有限公司| 亨沃机械设备有限公司| 四川沱江起重机有限公司| 佛山恒力泰机械有限公司| 大连港机械有限公司| 青州神工机械有限公司| 安钢闽源钢铁有限公司| 威海远兴机械有限公司| 徐州市机械有限公司| 贵州机械设备有限公司| 河南卫华重型机械有限公司| 无锡好麦机械有限公司| 昆山机械制造有限公司| 潍坊中迪机械有限公司| 上海陵城机械有限公司| 光大机械厂有限公司| 宁波力源机械有限公司| 莱州聚峰机械有限公司| 鑫华机械制造有限公司| 沈阳六合机械有限公司| 徐州永欣重工有限公司| 徐工辽宁机械有限公司| 鞍山宝得钢铁有限公司| 河南佳德机械有限公司| 江苏苏力机械有限公司| 上海春明机械制造有限公司| 江苏东邦机械有限公司| 济南钢铁 有限公司| 广州市京龙工程机械有限公司| 衡阳沃力机械有限公司| 台州中茂机械有限公司| 江苏中科机械有限公司| 昆山瑞钧机械设备有限公司| 上海玖钲机械设备有限公司| 成都刚毅机械制造有限公司| 江淮重工机械有限公司| 日晗精密机械有限公司| 杭州春江制药机械有限公司| 上海澳昊机械制造有限公司| 青岛博朗特机械设备有限公司 | 嘉兴市机械有限公司| 山东和晟机械设备有限公司| 苏州市机械制造有限公司| 苏州博扬机械有限公司| 宁波食品机械有限公司| 上海川源机械工程有限公司| 郑州双狮粮油机械有限公司| 浙江金辉机械有限公司| 常州欧鹰焊割机械有限公司| 济南庚辰钢铁有限公司| 兰州机械设备有限公司| 天津中核机械有限公司| 浙江汉克机械有限公司| 起航中文小说有限公司| 坎山机械有限公司招聘| 成都固特机械有限公司| 九龙机械制造有限公司| 青岛精密机械有限公司| 天津钢铁贸易有限公司| 东莞市乔锋机械有限公司| 溧阳布勒机械有限公司| 上海行雄机械有限公司| 徐州成日钢铁有限公司| 成都工程机械有限公司| 扬州高标机械有限公司| 农业机械有限公司招聘| 重庆春仁机械有限公司| 广州宏兴食品机械有限公司| 中信重工机器人有限公司| 温州 印刷机械有限公司| 荆州石油机械有限公司| 恩格尔机械上海有限公司| 徐州市机械有限公司| 烟台浩阳机械有限公司| 重庆红江机械有限公司| 广州联冠机械有限公司| 浙江大鹏机械有限公司| 浙江瑞尔斯机械有限公司| 莱州聚峰机械有限公司| 浙江远信印染机械有限公司| 力华机械设备有限公司| 山东博远重工有限公司| 淄博 机械有限公司| 辽阳腾龙钢铁有限公司| 兰州长征机械有限公司| 建材有限公司起名大全| 华东油压机械制造有限公司| 青岛新大成塑料机械有限公司 | 青岛万邦包装机械有限公司| 重庆嘉木机械有限公司| 无锡市机械制造有限公司| 青岛 机械制造有限公司| 台州宏汇机械有限公司| 宁波佳诚机械有限公司| 三国精密机械有限公司| 杭州精工机械有限公司| 昆山 精密机械有限公司| 腾达机械设备有限公司| 兖州丰业机械有限公司| 利星行机械昆山有限公司| 青岛大牧人机械有限公司招聘| 南京机械设备制造有限公司| 杭州星宏机械有限公司| 佛山市明宏机械设备有限公司| 大连 重工有限公司| 上海霏润机械设备有限公司| 郑州鼎盛机械有限公司| 马鞍山机械有限公司| 盐城市机械有限公司| 重庆科邦机械有限公司| 湖北铁正机械有限公司| 宁波安德机械有限公司| 吉林大华机械制造有限公司| 青岛唐宇机械制造有限公司| 广州永胜钢铁制品有限公司| 湖北机械制造有限公司| 长沙市机械有限公司| 杭州宏展机械有限公司| 浙江恒齿传动机械有限公司| 廊坊 包装机械有限公司| 江苏科圣化工机械有限公司| 济南农沃机械有限公司| 江苏省南扬机械制造有限公司| 江阴液压机械有限公司| 无锡祥靖机械有限公司| 苏州凯威塑料机械有限公司 | 荣嘉精密机械有限公司| 常州塑料机械有限公司| 浙江天联机械有限公司| 博可机械上海有限公司| 广州市广花包装机械有限公司| 镇江斯伊格机械有限公司| 佛山市精密机械有限公司| 联德精密机械有限公司| 湖南中旺工程机械设备有限公司 | 青州市国发包装机械有限公司 | 南京高立工程机械有限公司 | 上海机械装备有限公司| 浙江恒通机械有限公司| 大洋机械制造有限公司| 深圳市美鹏机械设备有限公司| 青岛希世可机械有限公司| 南京伟舜机械有限公司| 乐清市锐成机械有限公司| 徐州恒辉编织机械有限公司| 广州万举机械有限公司| 杭州同创顶立机械有限公司| 沈阳东荣机械有限公司| 力 机械 有限公司| 首钢长白机械有限公司| 汉中燕航精工机械有限公司| 南京三友机械有限公司| 瑞安市创博机械有限公司| 山东鲁成起重机械有限公司| 武安市裕华钢铁有限公司| 德州机械制造有限公司| 昆明群泰机械有限公司| 苏州宇钻机械有限公司| 天津 机械制造有限公司| 浙江先锋机械有限公司| 杭州正驰达精密机械有限公司| 苏州英维特精密机械有限公司| 宁波钢铁有限公司地址| 杭州通产机械有限公司| 扬州恒润海洋重工有限公司| 杭州 机械有限公司| 洛阳鹏起实业有限公司| 郑州恒科机械有限公司| 济南耐刻机械设备有限公司| 常州机械制造有限公司| 新湾机械有限公司招聘| 江苏普格机械有限公司| 精密机械配件有限公司| 深圳市康铖机械设备有限公司| 临沂江鑫钢铁有限公司| 葛洲坝机械船舶有限公司| 天津文洲机械有限公司| 福建 机械有限公司| 青岛德盛机械制造有限公司| 新乡市佳盛振动机械有限公司| 上海世达机械工具厂有限公司| 宁波佳尔灵气动机械有限公司 | 广东锐亚机械有限公司| 山东重特机械有限公司| 浙江长泰机械有限公司| 河南矿山机械有限公司| 石油机械设备有限公司| 常州纺织机械有限公司| 无锡前洲兴华机械有限公司| 四平方向机械有限公司| 成都液压机械有限公司| 成都弘邦机械有限公司| 开封元创机械有限公司| 金格瑞机械有限公司| 江苏利淮钢铁有限公司| 浙江鑫辉机械有限公司| 广东信昌机械有限公司| 浙江瑞安机械有限公司| 浙江达青机械有限公司| 南京恩梯恩精密机械有限公司| 山东英胜机械有限公司| 沈阳韩兆机械有限公司| 济南农沃机械有限公司| 广州新浪爱拓化工机械有限公司| 江苏金沃机械有限公司| 广意永雄机械有限公司| 武汉 机械有限公司| 浙江双鸟机械有限公司| 富信成机械有限公司| 福建申达钢铁有限公司| 上海安展机械设备有限公司| 杭州海的机械有限公司| 江苏华粮机械有限公司| 江苏瑞德机械有限公司| 宝鸡市机械有限公司| 建湖县液压机械有限公司| 上海卓越机械有限公司| 朝阳宏达机械有限公司| 唐山国义钢铁有限公司| 强大印刷机械有限公司| 眉山千层弹花机械有限公司| 上海天驰制药机械有限公司 | 昆山机械 有限公司| 浙江永达输送机械设备有限公司 | 河北鑫达钢铁有限公司| 青岛春风机械有限公司| 兴虎动力机械有限公司| 河南嵩山重工有限公司| 法麦凯尼柯机械有限公司| 江苏恩纳斯重工机械有限公司| 如皋市通达机械制造有限公司| 南宁敏创机械有限公司| 江苏医疗机械有限公司| 陕西锦泰机械有限公司| 石家庄米兹机械设备有限公司| 无锡万华机械有限公司| 四川高龙机械有限公司| 台州瑞进机械有限公司| 湖州三一重工有限公司| 上海淘乐机械有限公司| 普惠环保机械有限公司| 杭州康发塑料机械有限公司| 沧州昌鸿磨浆机械有限公司| 河南铁山起重设备有限公司| 食品机械制造有限公司| 苏州凯尔博精密机械有限公司| 厦门众达钢铁有限公司| 烟台万事达金属机械有限公司| 广东光信机械有限公司| 江苏霸马机械有限公司| 无锡远方机械有限公司| 宁波德霖机械有限公司| 徐州起重机械有限公司| 苏州海骏自动化机械有限公司 | 杭州诺迈机械有限公司| 雅康精密机械有限公司| 深圳包装机械有限公司| 深圳市美鹏机械设备有限公司| 江苏爱斯特机械有限公司怎么样 | 宇进注塑机械有限公司| 河北宏业机械有限公司| 上海舜诺机械有限公司| 新马木工机械有限公司| 浙江正润机械有限公司| 佶缔纳士机械有限公司| 汉虹精密机械有限公司| 北京现代京城工程机械有限公司| 江西欧克机械有限公司| 河北联港废钢铁回收有限公司| 南通龙威机械有限公司| 富利源机械有限公司| 上海川源机械工程有限公司| 扬州中孚机械有限公司| 江苏同力机械有限公司| 利勃海尔机械大连有限公司| 广东乐善机械有限公司| 济宁高扬工程机械有限公司| 许昌 机械有限公司| 佛山市康思达液压机械有限公司| 禹城 机械 有限公司| 涂装机械设备有限公司| 青州汇众机械有限公司| 亿德隆机械有限公司| 龙川航辉钢铁有限公司| 上海科熙起重设备有限公司| 无锡科创机械设计制造有限公司 | 武汉臻尚机械设备有限公司| 合肥海源机械有限公司| 新疆八一钢铁有限公司| 盐城市鑫益达精密机械有限公司| 无锡永兴机械制造有限公司| 天津泰威机械有限公司| 北京机械设备有限公司| 固精密机械有限公司| 武汉纵能机械制造有限公司| 永安五金机械有限公司| 林州市振晨重工装备制造有限公司 | 南京机械设备制造有限公司| 重庆明华机械有限公司| 浙江华昌液压机械有限公司| 北京明日之星玻璃机械有限公司| 安徽远鸿机械自动化有限公司| 高峰机械工业有限公司| 河南大方起重机有限公司| 集瑞联合重工有限公司| 苏州江源精密机械有限公司| 上海紫宏机械有限公司| 山东龙腾机械有限公司| 河南安普包装机械制造有限公司| 重庆维庆液压机械有限公司| 广州市金王机械设备有限公司| 新乡市中天机械有限公司 | 南京创博机械设备有限公司| 新乡市新久振动机械有限公司| 北京大森长空包装机械有限公司 | 浙江迅定钢铁有限公司| 桐乡 机械有限公司| 厦门大禾机械有限公司| 上海欧特莱阀门机械有限公司| 深圳旭生机械有限公司| 中核 天津 机械有限公司| 泉州宝隆机械有限公司| 上海保成机械有限公司| 上海戴服特包装机械有限公司| 湖北粮食机械有限公司| 上海木工机械有限公司| 广西利维重工有限公司| 洛阳重工机械有限公司| 常州东进机械有限公司| 广州东升机械有限公司| 苏州联屹精密机械有限公司| 唐山榕丰钢铁有限公司| 重庆阿德耐特动力机械有限公司| 万通机械制造有限公司| 济南建筑机械有限公司| 常州汤姆包装机械有限公司 | 合肥明泰机械施工有限公司| 武安市文安钢铁有限公司| 临清市机械有限公司| 乐星机械无锡有限公司| 东风悦达起亚汽车有限公司| 江苏永立机械有限公司| 上海金相机械有限公司| 上海三都机械有限公司| 起重机制造有限公司| 深圳精机械有限公司| 上海起重电机厂有限公司| 威海汇鑫化工机械有限公司| 江苏鸡煤机械有限公司| 秦皇岛秦冶重工有限公司| 江苏如皋钢铁有限公司| 邢台凌远机械制造有限公司 | 常矿起重机械有限公司| 安徽富鑫钢铁有限公司| 郑州未来机械制造有限公司| 山东鑫鑫机械有限公司| 杭州神钢建设机械有限公司| 宜兴市华鼎机械有限公司| 山东新船重工有限公司| 昆明机械制造有限公司| 张家港亿塑机械有限公司| 兴鑫钢铁有限公司电话| 普瑞特机械有限公司| 临沂金盛机械配套有限公司| 芜湖中安重工自动化装备有限公司| 上海玉程机械有限公司| 上海申越包装机械制造有限公司 | 鞍山源鑫钢铁有限公司| 四川青城机械有限公司| 苏州江源精密机械有限公司| 湖南湘船重工有限公司| 龙口富元机械有限公司| 杭州五金机械有限公司| 锦州俏牌机械有限公司| 郑州富民机械有限公司| 山西重工机械有限公司| 安溪永兴机械有限公司| 中山伙伴自动化机械有限公司 | 温州利捷机械有限公司| 洛阳市机械有限公司| 郑州江河重工有限公司| 重庆地泽机械有限公司| 人科机械设备有限公司| 昆山鑫建诚机械设备有限公司| 天津 机械制造有限公司| 深圳精机械有限公司| 宁波天瑞精工机械有限公司 | 东莞市沃德精密机械有限公司| 鲁山万通通机械制造有限公司| 河北冀工机械制造有限公司 | 河南黎明路桥重工有限公司| 沈阳 机械 有限公司| 无锡 液压机械有限公司| 宁波力源机械有限公司| 江苏东钢钢铁有限公司| 南通武藏精密机械有限公司招聘| 上海杰姆博机械设备有限公司 | 旭东机械昆山有限公司| 山东鲁工机械有限公司| 济宁金牛重工有限公司| 河南永康机械有限公司| 上海奕晟矿山机械有限公司| 江苏隆达机械设备有限公司| 江阴纺织机械有限公司| 上海 包装机械有限公司| 广州市机械有限公司| 派克包装机械有限公司| 焦作市机械制造有限公司| 济南机械制造有限公司| 扬州扬宝机械有限公司| 江苏食品机械有限公司| 上海市机械有限公司| 吉林吉钢钢铁有限公司| 卓郎新疆智能机械有限公司| 湖南五丰机械有限公司| 天津同盈钢铁有限公司| 上海冉本机械制造有限公司| 济南铭机械有限公司| 青岛胜代机械有限公司|