亚洲日韩av在线观看_日韩一级欧美一级_亚洲自偷自拍另类11p_久久午夜色播影院_中国黄色三级毛片_伊人久久一区二区三区小说_国产精品va无码二区_国产三区在线视频_69热视频_日本亚洲天堂_99精品少妇_国产区 在线观看_天堂一区二区三区_大片免费在线观看视频_免费看黄色一级片_黄色毛片特级_国产 麻豆 日韩 欧美 久久_国产一级淫片s片sss毛片s级_欧美爱爱视频_精品无码一区二区三区水蜜桃

當(dāng)前位置:首頁文章首頁 IT學(xué)院 PHP

PHP中常見數(shù)據(jù)庫問題及解決方法

作者:  來源:  發(fā)布時間:2011-5-28 9:34:48  點擊:
本文提到了關(guān)于PHP應(yīng)用程序中的五個常見數(shù)據(jù)庫問題,包括有數(shù)據(jù)庫模式設(shè)計、數(shù)據(jù)庫訪問和使用數(shù)據(jù)庫的業(yè)務(wù)邏輯代碼,以及教大家如何去解決這類問題,希望對大家有所幫助。

  如果只有一種 方式使用數(shù)據(jù)庫是正確的……

  您可以用很多的方式創(chuàng)建數(shù)據(jù)庫設(shè)計、數(shù)據(jù)庫訪問和基于數(shù)據(jù)庫的 PHP 業(yè)務(wù)邏輯代碼,但最終一般以錯誤告終。本文說明了數(shù)據(jù)庫設(shè)計和訪問數(shù)據(jù)庫的 PHP 代碼中出現(xiàn)的五個常見問題,以及在遇到這些問題時如何修復(fù)它們。

  問題 1:直接使用 MySQL

  一個常見問題是較老的 PHP 代碼直接使用 mysql_ 函數(shù)來訪問數(shù)據(jù)庫。清單 1 展示了如何直接訪問數(shù)據(jù)庫。

  清單 1. Access/get.php

 

<?php
function get_user_id( $name )
{
 $db = mysql_connect( 'localhost', 'root', 'password' );
 mysql_select_db( 'users' );

 $res = mysql_query( "SELECT id FROM users WHERE login='".$name."'" );
 while( $row = mysql_fetch_array( $res ) ) { $id = $row[0]; }

 return $id;
}

var_dump( get_user_id( 'jack' ) );
?>


  注意使用了 mysql_connect 函數(shù)來訪問數(shù)據(jù)庫。還要注意查詢,其中使用字符串連接來向查詢添加 $name 參數(shù)。

  該技術(shù)有兩個很好的替代方案:PEAR DB 模塊和 PHP Data Objects (PDO) 類。兩者都從特定數(shù)據(jù)庫選擇提供抽象。因此,您的代碼無需太多調(diào)整就可以在 IBM? DB2?、MySQL、PostgreSQL 或者您想要連接到的任何其他數(shù)據(jù)庫上運行。

  使用 PEAR DB 模塊和 PDO 抽象層的另一個價值在于您可以在 SQL 語句中使用 ? 操作符。這樣做可使 SQL 更加易于維護,且可使您的應(yīng)用程序免受 SQL 注入攻擊。

  使用 PEAR DB 的替代代碼如下所示。

  清單 2. Access/get_good.php

 

<?php
require_once("DB.php");

function get_user_id( $name )
{
 $dsn = 'mysql://root:password@localhost/users';
 $db =& DB::Connect( $dsn, array() );
 if (PEAR::isError($db)) { die($db->getMessage()); }

 $res = $db->query( 'SELECT id FROM users WHERE login=?',array( $name ) );
 $id = null;
 while( $res->fetchInto( $row ) ) { $id = $row[0]; }

 return $id;
}

var_dump( get_user_id( 'jack' ) );
?>


  注意,所有直接用到 MySQL 的地方都消除了,只有 $dsn 中的數(shù)據(jù)庫連接字符串除外。此外,我們通過 ? 操作符在 SQL 中使用 $name 變量。然后,查詢的數(shù)據(jù)通過 query() 方法末尾的 array 被發(fā)送進來。

  問題 2:不使用自動增量功能

  與大多數(shù)現(xiàn)代數(shù)據(jù)庫一樣,MySQL 能夠在每記錄的基礎(chǔ)上創(chuàng)建自動增量惟一標(biāo)識符。除此之外,我們?nèi)匀粫吹竭@樣的代碼,即首先運行一個 SELECT 語句來找到最大的 id,然后將該 id 增 1,并找到一個新記錄。清單 3 展示了一個示例壞模式。

  清單 3. Badid.sql

 

DROP TABLE IF EXISTS users;
CREATE TABLE users (
id MEDIUMINT,
login TEXT,
password TEXT
);

INSERT INTO users VALUES ( 1, 'jack', 'pass' );
INSERT INTO users VALUES ( 2, 'joan', 'pass' );
INSERT INTO users VALUES ( 1, 'jane', 'pass' );


  這里的 id 字段被簡單地指定為整數(shù)。所以,盡管它應(yīng)該是惟一的,我們還是可以添加任何值,如 CREATE 語句后面的幾個 INSERT 語句中所示。清單 4 展示了將用戶添加到這種類型的模式的 PHP 代碼。

  清單 4. Add_user.php

 

<?php
require_once("DB.php");

function add_user( $name, $pass )
{
 $rows = array();

 $dsn = 'mysql://root:password@localhost/bad_badid';
 $db =& DB::Connect( $dsn, array() );
 if (PEAR::isError($db)) { die($db->getMessage()); }

 $res = $db->query( "SELECT max(id) FROM users" );
 $id = null;
 while( $res->fetchInto( $row ) ) { $id = $row[0]; }

 $id += 1;

 $sth = $db->prepare( "INSERT INTO users VALUES(?,?,?)" );
 $db->execute( $sth, array( $id, $name, $pass ) );

 return $id;
}

$id = add_user( 'jerry', 'pass' );

var_dump( $id );
?>


  add_user.php 中的代碼首先執(zhí)行一個查詢以找到 id 的最大值。然后文件以 id 值加 1 運行一個 INSERT 語句。該代碼在負(fù)載很重的服務(wù)器上會在競態(tài)條件中失敗。另外,它也效率低下。

  那么替代方案是什么呢?使用 MySQL 中的自動增量特性來自動地為每個插入創(chuàng)建惟一的 ID。更新后的模式如下所示。

  清單 5. Goodid.php

 

DROP TABLE IF EXISTS users;
CREATE TABLE users (
 id MEDIUMINT NOT NULL AUTO_INCREMENT,
 login TEXT NOT NULL,
 password TEXT NOT NULL,
 PRIMARY KEY( id )
);

INSERT INTO users VALUES ( null, 'jack', 'pass' );
INSERT INTO users VALUES ( null, 'joan', 'pass' );
INSERT INTO users VALUES ( null, 'jane', 'pass' );


  我們添加了 NOT NULL 標(biāo)志來指示字段必須不能為空。我們還添加了 AUTO_INCREMENT 標(biāo)志來指示字段是自動增量的,添加 PRIMARY KEY 標(biāo)志來指示那個字段是一個 id。這些更改加快了速度。清單 6 展示了更新后的 PHP 代碼,即將用戶插入表中。

  清單 6. Add_user_good.php

 

<?php
require_once("DB.php");

function add_user( $name, $pass )
{
 $dsn = 'mysql://root:password@localhost/good_genid';
 $db =& DB::Connect( $dsn, array() );
 if (PEAR::isError($db)) { die($db->getMessage()); }

 $sth = $db->prepare( "INSERT INTO users VALUES(null,?,?)" );
 $db->execute( $sth, array( $name, $pass ) );

 $res = $db->query( "SELECT last_insert_id()" );
 $id = null;
 while( $res->fetchInto( $row ) ) { $id = $row[0]; }

 return $id;
}

$id = add_user( 'jerry', 'pass' );

var_dump( $id );
?>


  現(xiàn)在我不是獲得最大的 id 值,而是直接使用 INSERT 語句來插入數(shù)據(jù),然后使用 SELECT 語句來檢索最后插入的記錄的 id。該代碼比最初的版本及其相關(guān)模式要簡單得多,且效率更高。

  問題 3:使用多個數(shù)據(jù)庫

  偶爾,我們會看到一個應(yīng)用程序中,每個表都在一個單獨的數(shù)據(jù)庫中。在非常大的數(shù)據(jù)庫中這樣做是合理的,但是對于一般的應(yīng)用程序,則不需要這種級別的分割。此外,不能跨數(shù)據(jù)庫執(zhí)行關(guān)系查詢,這會影響使用關(guān)系數(shù)據(jù)庫的整體思想,更不用說跨多個數(shù)據(jù)庫管理表會更困難了。 那么,多個數(shù)據(jù)庫應(yīng)該是什么樣的呢?首先,您需要一些數(shù)據(jù)。清單 7 展示了分成 4 個文件的這樣的數(shù)據(jù)。

  清單 7. 數(shù)據(jù)庫文件

 

Files.sql:
CREATE TABLE files (
 id MEDIUMINT,
 user_id MEDIUMINT,
 name TEXT,
 path TEXT
);

Load_files.sql:
INSERT INTO files VALUES ( 1, 1, 'test1.jpg', 'files/test1.jpg' );
INSERT INTO files VALUES ( 2, 1, 'test2.jpg', 'files/test2.jpg' );

Users.sql:
DROP TABLE IF EXISTS users;
CREATE TABLE users (
 id MEDIUMINT,
 login TEXT,
 password TEXT
);

Load_users.sql:
INSERT INTO users VALUES ( 1, 'jack', 'pass' );
INSERT INTO users VALUES ( 2, 'jon', 'pass' );


  在這些文件的多數(shù)據(jù)庫版本中,您應(yīng)該將 SQL 語句加載到一個數(shù)據(jù)庫中,然后將 users SQL 語句加載到另一個數(shù)據(jù)庫中。用于在數(shù)據(jù)庫中查詢與某個特定用戶相關(guān)聯(lián)的文件的 PHP 代碼如下所示。

  清單 8. Getfiles.php

 

<?php
require_once("DB.php");

function get_user( $name )
{
 $dsn = 'mysql://root:password@localhost/bad_multi1';
 $db =& DB::Connect( $dsn, array() );
 if (PEAR::isError($db)) { die($db->getMessage()); }

 $res = $db->query( "SELECT id FROM users WHERE login=?",array( $name ) );
 $uid = null;
 while( $res->fetchInto( $row ) ) { $uid = $row[0]; }

 return $uid;
}

function get_files( $name )
{
 $uid = get_user( $name );

 $rows = array();

 $dsn = 'mysql://root:password@localhost/bad_multi2';
 $db =& DB::Connect( $dsn, array() );
 if (PEAR::isError($db)) { die($db->getMessage()); }

 $res = $db->query( "SELECT * FROM files WHERE user_id=?",array( $uid ) );
 while( $res->fetchInto( $row ) ) { $rows[] = $row; }
 return $rows;
}

$files = get_files( 'jack' );

var_dump( $files );
?>


  get_user 函數(shù)連接到包含用戶表的數(shù)據(jù)庫并檢索給定用戶的 ID。get_files 函數(shù)連接到文件表并檢索與給定用戶相關(guān)聯(lián)的文件行。
 做所有這些事情的一個更好辦法是將數(shù)據(jù)加載到一個數(shù)據(jù)庫中,然后執(zhí)行查詢,比如下面的查詢。

  清單 9. Getfiles_good.php

 

<?php
require_once("DB.php");

function get_files( $name )
{
 $rows = array();

 $dsn = 'mysql://root:password@localhost/good_multi';
 $db =& DB::Connect( $dsn, array() );
 if (PEAR::isError($db)) { die($db->getMessage()); }

 $res = $db->query("SELECT files.* FROM users, files WHERE
users.login=? AND users.id=files.user_id",
array( $name ) );
 while( $res->fetchInto( $row ) ) { $rows[] = $row; }

 return $rows;
}

$files = get_files( 'jack' );

var_dump( $files );
?>


  該代碼不僅更短,而且也更容易理解和高效。我們不是執(zhí)行兩個查詢,而是執(zhí)行一個查詢。

  盡管該問題聽起來有些牽強,但是在實踐中我們通常總結(jié)出所有的表應(yīng)該在同一個數(shù)據(jù)庫中,除非有非常迫不得已的理由。

  問題 4:不使用關(guān)系---www.002pc.com

  關(guān)系數(shù)據(jù)庫不同于編程語言,它們不具有數(shù)組類型。相反,它們使用表之間的關(guān)系來創(chuàng)建對象之間的一到多結(jié)構(gòu),這與數(shù)組具有相同的效果。我在應(yīng)用程序中看到的一個問題是,工程師試圖將數(shù)據(jù)庫當(dāng)作編程語言來使用,即通過使用具有逗號分隔的標(biāo)識符的文本字符串來創(chuàng)建數(shù)組。請看下面的模式。

  清單 10. Bad.sql

 

DROP TABLE IF EXISTS files;
CREATE TABLE files (
 id MEDIUMINT,
 name TEXT,
 path TEXT
);

DROP TABLE IF EXISTS users;
CREATE TABLE users (
 id MEDIUMINT,
 login TEXT,
 password TEXT,
 files TEXT
);

INSERT INTO files VALUES ( 1, 'test1.jpg', 'media/test1.jpg' );
INSERT INTO files VALUES ( 2, 'test1.jpg', 'media/test1.jpg' );
INSERT INTO users VALUES ( 1, 'jack', 'pass', '1,2' );


  系統(tǒng)中的一個用戶可以具有多個文件。在編程語言中,應(yīng)該使用數(shù)組來表示與一個用戶相關(guān)聯(lián)的文件。在本例中,程序員選擇創(chuàng)建一個 files 字段,其中包含一個由逗號分隔的文件 id 列表。要得到一個特定用戶的所有文件的列表,程序員必須首先從用戶表中讀取行,然后解析文件的文本,并為每個文件運行一個單獨的 SELECT 語句。該代碼如下所示。

  清單 11. Get.php

 

<?php
require_once("DB.php");

function get_files( $name )
{
 $dsn = 'mysql://root:password@localhost/bad_norel';
 $db =& DB::Connect( $dsn, array() );
 if (PEAR::isError($db)) { die($db->getMessage()); }

 $res = $db->query( "SELECT files FROM users WHERE login=?",array( $name ) );
 $files = null;
 while( $res->fetchInto( $row ) ) { $files = $row[0]; }

 $rows = array();

 foreach( split( ',',$files ) as $file )
 {
  $res = $db->query( "SELECT * FROM files WHERE id=?",
  array( $file ) );
  while( $res->fetchInto( $row ) ) { $rows[] = $row; }
 }

 return $rows;
}

$files = get_files( 'jack' );

var_dump( $files );
?>


  該技術(shù)很慢,難以維護,且沒有很好地利用數(shù)據(jù)庫。惟一的解決方案是重新架構(gòu)模式,以將其轉(zhuǎn)換回到傳統(tǒng)的關(guān)系形式,如下所示。

  清單 12. Good.sql

 

DROP TABLE IF EXISTS files;
CREATE TABLE files (
 id MEDIUMINT,
 user_id MEDIUMINT,
 name TEXT,
 path TEXT
);

DROP TABLE IF EXISTS users;
CREATE TABLE users (
 id MEDIUMINT,
 login TEXT,
 password TEXT
);

INSERT INTO users VALUES ( 1, 'jack', 'pass' );
INSERT INTO files VALUES ( 1, 1, 'test1.jpg', 'media/test1.jpg' );
INSERT INTO files VALUES ( 2, 1, 'test1.jpg', 'media/test1.jpg' );


  這里,每個文件都通過 user_id 函數(shù)與文件表中的用戶相關(guān)。這可能與任何將多個文件看成數(shù)組的人的思想相反。當(dāng)然,數(shù)組不引用其包含的對象 —— 事實上,反之亦然。但是在關(guān)系數(shù)據(jù)庫中,工作原理就是這樣的,并且查詢也因此要快速且簡單得多。清單 13 展示了相應(yīng)的 PHP 代碼。

  清單 13. Get_good.php

 

<?php
require_once("DB.php");

function get_files( $name )
{
 $dsn = 'mysql://root:password@localhost/good_rel';
 $db =& DB::Connect( $dsn, array() );
 if (PEAR::isError($db)) { die($db->getMessage()); }

 $rows = array();
 $res = $db->query("SELECT files.* FROM users,files WHERE users.login=?
AND users.id=files.user_id",array( $name ) );
 while( $res->fetchInto( $row ) ) { $rows[] = $row; }
 return $rows;
}

$files = get_files( 'jack' );

var_dump( $files );
?>


  這里,我們對數(shù)據(jù)庫進行一次查詢,以獲得所有的行。代碼不復(fù)雜,并且它將數(shù)據(jù)庫作為其原有的用途使用。

  問題 5:n+1 模式

  我真不知有多少次看到過這樣的大型應(yīng)用程序,其中的代碼首先檢索一些實體(比如說客戶),然后來回地一個一個地檢索它們,以得到每個實體的詳細(xì)信息。我們將其稱為 n+1 模式,因為查詢要執(zhí)行這么多次 —— 一次查詢檢索所有實體的列表,然后對于 n 個實體中的每一個執(zhí)行一次查詢。當(dāng) n=10 時這還不成其為問題,但是當(dāng) n=100 或 n=1000 時呢?然后肯定會出現(xiàn)低效率問題。清單 14 展示了這種模式的一個例子。

  清單 14. Schema.sql

 

DROP TABLE IF EXISTS authors;
CREATE TABLE authors (
 id MEDIUMINT NOT NULL AUTO_INCREMENT,
 name TEXT NOT NULL,
 PRIMARY KEY ( id )
);

DROP TABLE IF EXISTS books;
CREATE TABLE books (
 id MEDIUMINT NOT NULL AUTO_INCREMENT,
 author_id MEDIUMINT NOT NULL,
 name TEXT NOT NULL,
 PRIMARY KEY ( id )
);

INSERT INTO authors VALUES ( null, 'Jack Herrington' );
INSERT INTO authors VALUES ( null, 'Dave Thomas' );

INSERT INTO books VALUES ( null, 1, 'Code Generation in Action' );
INSERT INTO books VALUES ( null, 1, 'Podcasting Hacks' );
INSERT INTO books VALUES ( null, 1, 'PHP Hacks' );
INSERT INTO books VALUES ( null, 2, 'Pragmatic Programmer' );
INSERT INTO books VALUES ( null, 2, 'Ruby on Rails' );
INSERT INTO books VALUES ( null, 2, 'Programming Ruby' );


  該模式是可靠的,其中沒有任何錯誤。問題在于訪問數(shù)據(jù)庫以找到一個給定作者的所有書籍的代碼中,如下所示。

  清單 15. Get.php

 

<?php
require_once('DB.php');

$dsn = 'mysql://root:password@localhost/good_books';
$db =& DB::Connect( $dsn, array() );
if (PEAR::isError($db)) { die($db->getMessage()); }

function get_author_id( $name )
{
 global $db;

 $res = $db->query( "SELECT id FROM authors WHERE name=?",array( $name ) );
 $id = null;
 while( $res->fetchInto( $row ) ) { $id = $row[0]; }
 return $id;
}

function get_books( $id )
{
 global $db;

 $res = $db->query( "SELECT id FROM books WHERE author_id=?",array( $id ) );
 $ids = array();
 while( $res->fetchInto( $row ) ) { $ids []= $row[0]; }
 return $ids;
}

function get_book( $id )
{
 global $db;

 $res = $db->query( "SELECT * FROM books WHERE id=?", array( $id ) );
 while( $res->fetchInto( $row ) ) { return $row; }
 return null;
}

$author_id = get_author_id( 'Jack Herrington' );
$books = get_books( $author_id );
foreach( $books as $book_id ) {
 $book = get_book( $book_id );
 var_dump( $book );
}
?>


  如果您看看下面的代碼,您可能會想,“嘿,這才是真正的清楚明了。” 首先,得到作者 id,然后得到書籍列表,然后得到有關(guān)每本書的信息。的確,它很清楚明了,但是其高效嗎?回答是否定的?纯粗皇菣z索 Jack Herrington 的書籍時要執(zhí)行多少次查詢。一次獲得 id,另一次獲得書籍列表,然后每本書執(zhí)行一次查詢。三本書要執(zhí)行五次查詢!

  解決方案是用一個函數(shù)來執(zhí)行大量的查詢,如下所示。

  清單 16. Get_good.php

 

<?php
require_once('DB.php');

$dsn = 'mysql://root:password@localhost/good_books';
$db =& DB::Connect( $dsn, array() );
if (PEAR::isError($db)) { die($db->getMessage()); }

function get_books( $name )
{
 global $db;

 $res = $db->query("SELECT books.* FROM authors,books WHERE books.author_id=authors.id AND authors.name=?",
 array( $name ) );
 $rows = array();
 while( $res->fetchInto( $row ) ) { $rows []= $row; }
  return $rows;
 }

 $books = get_books( 'Jack Herrington' );
 var_dump( $books );
?>


  現(xiàn)在檢索列表需要一個快速、單個的查詢。這意味著我將很可能必須具有幾個這些類型的具有不同參數(shù)的方法,但是實在是沒有選擇。如果您想要具有一個擴展的 PHP 應(yīng)用程序,那么必須有效地使用數(shù)據(jù)庫,這意味著更智能的查詢。

  本例的問題是它有點太清晰了。通常來說,這些類型的 n+1 或 n*n 問題要微妙得多。并且它們只有在數(shù)據(jù)庫管理員在系統(tǒng)具有性能問題時在系統(tǒng)上運行查詢剖析器時才會出現(xiàn)。

  結(jié)束語

  數(shù)據(jù)庫是強大的工具,就跟所有強大的工具一樣,如果您不知道如何正確地使用就會濫用它們。識別和解決這些問題的訣竅是更好地理解底層技術(shù)。長期以來,我老聽到業(yè)務(wù)邏輯編寫人員抱怨,他們不想要必須理解數(shù)據(jù)庫或 SQL 代碼。他們把數(shù)據(jù)庫當(dāng)成對象使用,并疑惑性能為什么如此之差。

  他們沒有認(rèn)識到,理解 SQL 對于將數(shù)據(jù)庫從一個困難的必需品轉(zhuǎn)換成強大的聯(lián)盟是多么重要。如果您每天使用數(shù)據(jù)庫,但是不熟悉 SQL,那么請閱讀 The Art of SQL,這本書寫得很好,實踐性也很強,可以指導(dǎo)您基本了解數(shù)據(jù)庫。

文章評論

軟件按字母排列: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
主站蜘蛛池模板: 英特美光电有限公司| 晶光华电子有限公司| 迪卡侬上海体育用品有限公司| 百超精密机床有限公司| 贵州 不锈钢 有限公司| 惠州市金丰有限公司| 0312 . 有限公司| 友谊班尼路服饰有限公司| 山东法因数控有限公司| 世纪华通汽车部件有限公司| 吉林金冠电气有限公司| 冠牌光电技术有限公司| 安防监控技术有限公司| 埃克森美孚天津石油有限公司| 温州鸿建设有限公司| 蓝海国际贸易有限公司| 湖北正奥汽车附件有限公司| 汉丰建筑设计有限公司| 新疆奇康哈博维药有限公司 | 燕京啤酒贵州有限公司| 宁德进出口有限公司| 宝鸡今麦郎有限公司| 泰山耐火材料有限公司| 诚景进出口有限公司| 博盛国际贸易有限公司| 苏州吴江的发展有限公司| 中石油东北炼化工程有限公司| 武钢新日铁有限公司| 松下马达(杭州)有限公司| 张万福珠宝有限公司| 威时沛运货运有限公司| 中核能源发展有限公司| 发酵 工程有限公司| 昆山热压板有限公司| 岛味美食品有限公司| 名气通电讯有限公司| 业和新能源有限公司| 美国苹果服饰有限公司| 贵州玉茅酒业有限公司| 三强电子深圳有限公司| 乐美化妆品有限公司| 高木安防设备有限公司| 常州东霞印染有限公司| 宗申电动车有限公司| 泰锐有限公司怎么样| 宏晟机械设备有限公司| 惠州市建设工程监理有限公司| 九源北京国际建筑顾问有限公司 | 乳品机械制造有限公司| 圣和圣置业有限公司| 华润上华半导体有限公司| TCL通讯设备惠州有限公司| 美华包装材料有限公司| 德莱赛机械 苏州 有限公司| 广州市清洁设备有限公司| 九州实业发展有限公司| 金岷江机电设备有限公司| 三星显示器苏州有限公司| 王家峪煤业有限公司| 昆山 研华 有限公司| 上海默沙东制药有限公司| 江铃轻型汽车有限公司| 和锲电子 有限公司| 科利华电器有限公司| 淮安楚州区 有限公司| 广东东方精工有限公司| 哈尔滨肥黄金生物有限公司| 西安利君制药有限公司| 美建建筑系统有限公司| 深圳鸿迈电子有限公司| 佛山市 窗帘有限公司| 苏州联网技术有限公司| 福州厨具设备有限公司| 漳州园食品有限公司| 天津国大药房有限公司| 济宁莱尼电气系统有限公司| 顺德区悦电器有限公司| 成峰流体设备有限公司| 上海连锁发展有限公司| 津上精密机床有限公司| 泰州环球传动有限公司| 沈阳芯源电子设备有限公司| 远达五金制品有限公司| 强盛建筑工程有限公司| 海睿兴实业有限公司| 艾普斯电源苏州有限公司| 安国市生物有限公司| 辉煌国际贸易有限公司| 江苏森达热电有限公司| 重庆银河仪器有限公司| 成都棒棒娃实业有限公司| 河南塑胶制品有限公司| 上海蓉易贸易有限公司| 德纳(南京)化工有限公司| 茂名石化工程有限公司| 岑溪 食品 有限公司| 河南电气自动化有限公司| 广州大家乐食品有限公司| 佛山市船务有限公司| 东莞科进实业有限公司| 麦锡金属处理有限公司| 中山卫浴制造有限公司| 烟台环保疏浚有限公司| 北京百泰生物技术有限公司 | 北京青云设备有限公司| 富电电子惠州有限公司| 义乌钢结构有限公司| 唐山中材重型机械有限公司| 艺宇印刷包装有限公司| 亚是加食品有限公司| 威尔(福建)生物有限公司| 帕捷汽车配件上海有限公司| 广东汤臣倍健有限公司| 必图实业 东莞 有限公司| 富裕注塑制模上海有限公司| 连云港纸业有限公司| 青岛包装辅料有限公司| 深圳市福鑫电子有限公司| 华数信息技术有限公司| 迅达电子苏州有限公司| 德州恒业置业有限公司| 迈克斯化工有限公司| 康达汽车工贸有限公司| 湖南农牧发展有限公司| 沃盛(上海)有限公司| 塑旺塑胶原料有限公司| 新兴利合成纤维有限公司| 南丰电机制造有限公司| 山东省轮胎有限公司| 常熟市合金材料有限公司| 鑫苑置业(成都)有限公司| 金湖建设工程有限公司| 锦州自动化设备有限公司| 典道体育用品有限公司| 万唯教育图书有限公司| 辽宁华丰化工有限公司| 河南新大新材料有限公司| 利纳马 天津 有限公司| 一树山国际设计有限公司 | 河南邦杰食品有限公司| 北京建筑工程装饰有限公司| 深圳市长方照明有限公司| 成大方圆连锁有限公司| 天津中环仪表有限公司| 深圳市金顶有限公司| 翔森建设工程有限公司| 中农高科北京有限公司| 深圳青岛朝日啤酒有限公司| 北京知蜂堂有限公司| 冠嘉上海服饰有限公司| 深圳琦富电子有限公司| 东阳荣鑫酒业有限公司| 永久自行车有限公司| 东莞金旺食品有限公司| 元正建筑设计有限公司| 华越(深圳)电子有限公司| 深圳市奇科电子有限公司| 云测信息技术有限公司| 苏州体育设施有限公司| 利铭金属制品有限公司| 上海格易电子有限公司| 中源盛祥担保有限公司| 泉州泉航机械有限公司| 金鑫源实业有限公司| 武汉船舶制造有限公司| 深圳市吉蓝有限公司| 柯尔柏上海有限公司| 天津南港港务有限公司| 荣成橡胶制品有限公司| 正泰汽车零部件有限公司| 诚科自动化有限公司| 苏州太服饰有限公司| 上海亚创工程技术有限公司| 太安堂药业有限公司| 青岛源至诚实业有限公司| 小川香料 上海 有限公司| 戎威远保安有限公司| 金腾装饰工程有限公司| 深圳市鹏发电子有限公司| 新协力包装制品有限公司| 柏物产食品有限公司| 北京捷众汽车有限公司| 东莞市良品塑胶制品有限公司| 中山台光电子有限公司| 欣贺厦门服饰有限公司| 南北药行连锁有限公司| 深圳市雄帝有限公司| 富山阀门实业苏州有限公司| 鄂尔多斯绿能光电有限公司| 东风鸿泰销售有限公司| 江苏健身器材有限公司| 科太环境技术有限公司| 广州市展辉电子有限公司| 中信设备安装有限公司| 雾博信息技术有限公司| 福州生普贸易有限公司| 深圳锦泰电子有限公司| 铁科首钢轨道技术有限公司| 北京瑞宝食品有限公司| 深圳市小家电有限公司| 上海昆山电子有限公司| 南汽模具装备有限公司| 中铁物资重庆有限公司| 浙江净化设备有限公司| 远铭装饰工程有限公司| tcl财务有限公司| 广州巧巧贸易有限公司| 盛汇国际贸易有限公司| 深圳盈辉电子有限公司| 妥思空调苏州有限公司| 聚赛龙工程塑料有限公司| 大连品尔食品有限公司| 三环离合器有限公司| 稳得电子(昆山)有限公司| 天津国旅行社有限公司| 华东钢结构有限公司| 海银金融 有限公司招| 倍康信息技术有限公司| 江苏和兴汽车有限公司| 沃德(天津)传动有限公司| 东瑞机电设备有限公司| 东北阜丰生物有限公司| 光大通信设备有限公司| 群泰机械设备有限公司| 吉林市器材有限公司| 苏州嘉基电子有限公司| 江阴恒扬新型建材有限公司| 普氏电机常熟有限公司| 湖南金华达建材有限公司| 普尔信通讯有限公司| 兴盛塑料制品有限公司| 上海尚欧家纺有限公司| 重庆川东化工有限公司| 中交融租赁有限公司| 沈阳日野汽车有限公司| 深圳哈德斯有限公司| 深圳 汽配有限公司| 苏州恒富威有限公司| 深圳市康讯电子有限公司| 江阴华 缆有限公司| 英皇钟表珠宝有限公司| 华科泰生物技术有限公司| 浙江凯 医药有限公司| 中山日塑电子有限公司| 珠海长兴化学材料有限公司| 天津中矿联合贵金属经营有限公司| 瑞鸿新材料有限公司| 深圳华圳融资担保有限公司| 爱力液压密封技术有限公司| 重庆大新药业有限公司| 塔牌绍兴酒有限公司| 华泰贵金属有限公司| 快客利餐饮有限公司| 佛山恒泰实业有限公司| 深圳市金联电子有限公司| 福州 化纤有限公司| 上海携程旅游有限公司| 蚌埠华益玻璃有限公司| 宏丰工艺品有限公司| 常州特种涂料有限公司| 稳得电子(昆山)有限公司| 冷却系统天津有限公司 | 克模模具苏州有限公司| 丽鑫化妆品有限公司| 南昌光明化验设备有限公司| 广州 鑫人和有限公司| 希革斯上海有限公司| 江门华敏电器有限公司| 广东永鸿钟表有限公司| 可颜化妆品有限公司| 武汉正维电子有限公司| 深圳市纳海电子有限公司| 中铁十三局第二工程有限公司| 沃川电子苏州有限公司| 杭州鑫富药业有限公司| 东莞鑫联电子有限公司| 成都山田车用部品有限公司| 天津市宏顺有限公司| 艾普尔换热器有限公司| 国基电子中山有限公司| 上鱼舫餐饮有限公司| 耐落螺丝 昆山 有限公司| 凡纳克塑胶膜有限公司| 山东健康有限公司怎么样| 深圳迪斯科有限公司| 昆山 稳得电子有限公司| 新阳天津化工有限公司| 杭州群丰果品连锁有限公司| 华亿妇幼用品有限公司| 无印良品商业有限公司| 北京华路信息技术有限公司 | 蚌埠华益导电膜玻璃有限公司| 河南水处理技术有限公司| 长安福特汽车有限公司杭州| 广州掌联信息技术有限公司| 济南电器制造有限公司| 惠州 儿童 有限公司| 华电(北京)热电有限公司| 宁波天普橡胶有限公司| 海睿兴实业有限公司| 四川天全水泥有限公司| 万达转向系统有限公司| 坤兴海洋生物有限公司| 宝展信息技术有限公司| 西安华润置地有限公司| 北京天健仪表有限公司| 中材进出口有限公司| 杭州浙宝电气有限公司| 武汉市担保有限公司| 南京中药饮片有限公司| 首都建筑设计有限公司| 楚味香食品有限公司| 诺力机械设备有限公司| 天时印刷深圳有限公司| 江苏黄河药业有限公司| 中粮万威客有限公司| 上海众业通电缆有限公司| 成都燃气有限公司招聘| 深圳市博蓝电子有限公司| 华电南疆热电有限公司| 莱尼电气系统 济宁 有限公司| 四川汉舟电气有限公司| 正大上海有限公司地址| 浙江石油销售有限公司| 浙江金华化工有限公司| 中冶美利纸业有限公司| 上海原品食品有限公司| 欧林 上海 有限公司| 微时代信息技术有限公司| 有为信息技术发展有限公司| 广州骏业料有限公司| 华润电力常熟有限公司| 深圳富创光电有限公司| 浪潮lg数字移动通信有限公司| 上海基发实业有限公司| 深圳市亚泰电子有限公司| 四川里伍铜业有限公司| 固特电子(深圳)有限公司| 中铁物资华南有限公司| 亿龙汽车销售有限公司| 东莞市佳 鞋业有限公司| 上海顺发实业有限公司| 东莞源林电子有限公司| 佛山市厨具电器有限公司| 礼信有限公司怎么样| 华新建设工程有限公司| 重庆智翔铺道技术工程有限公司 | 滨州戴卡轮毂有限公司| 江苏苏华泵业有限公司| 翔宇医疗设备有限公司| 杭州塑料模具有限公司| 济南富化工有限公司| 杰亮光电(深圳)有限公司| 肇庆通产玻璃有限公司| 无锡数控刀具有限公司| 吉林一正药业有限公司| 天津速冻食品有限公司| 艾恩司(苏州)有限公司| 苏州易程智能系统有限公司| 金博机械制造有限公司| 日照环保能源有限公司| 黑美人茶业有限公司| 北京长城华冠有限公司| 无锡电动工具有限公司| 华宁电气实业有限公司| 深圳四方精创资讯有限公司| 铝合金压铸有限公司| 优斯特电子有限公司| 深圳航天物业有限公司| 百车行汽车销售有限公司| 江西博雅生物有限公司| 高明森和园食品有限公司| 宁波 塑料 贸易有限公司| 国信商品交易有限公司| 日铁金属制品有限公司| 东莞的富相电子有限公司| 海永昌电子有限公司| 番禺音响设备有限公司| 兴信塑胶制品有限公司| 广州思迪电子有限公司| 延锋百利得汽车安全系统有限公司 | 陕西新型材料有限公司| 华声达电子有限公司| 中骏建设工程有限公司| 东莞太阳能玻璃有限公司| 中山美图塑料有限公司| 海宏建设工程有限公司| 广州历高服饰有限公司| 金秋装饰工程有限公司| 绵阳汽车配件有限公司| 明日电器设备有限公司| 海纳医疗器械有限公司| 深圳市百味餐饮有限公司| 深圳市帷幄技术有限公司| 青岛 邦 饲料有限公司| 山东消防器材有限公司| 东芝堂药业有限公司| 台前县食品有限公司| 高时石材上海有限公司| 东莞市欧源有限公司| 旭光聚合物有限公司| 天津长兴化学有限公司| 皇家建筑系统有限公司| 广东长食品有限公司| 三乐门窗幕墙工程有限公司| 优的生活电器有限公司| 江阴新日冶金有限公司| 成都丝语美容咨有限公司| 北京五棵松有限公司| 湖南消防器材有限公司| 瑞虎精细化工有限公司| 三和重工机械有限公司| 常熟豪翔针织有限公司| 日日辉照明有限公司| 凯尔博超声波有限公司| 国际信和贸易有限公司| 昆明航空票务有限公司| 上海博设计有限公司怎么样| 上海闵行能源有限公司| 电站辅机总厂有限公司| 北京市机电技术有限公司| 深圳新程电子有限公司| 长兴精细涂料有限公司| 纺联进出口有限公司| 娄底建筑工程有限公司| 和其正食品有限公司| 中塑进出口有限公司| 福州太阳电缆有限公司| 摩根碳制品有限公司| 空调电器设备有限公司| 浙江南都物业有限公司| 南京紫金电子有限公司| 四方源实业有限公司| 本田贸易有限公司广州| 两江新区发展有限公司| 滁州市贸易有限公司| 艾默生电机有限公司| 鼎盛装饰设计有限公司| 好唯加食品有限公司| 富德能源化工发展有限公司| 陕西尧柏水泥有限公司| 埃森哲上海有限公司| 宏庄建筑工程有限公司| 深圳凯丰实业有限公司| 三亚德航空港有限公司| 国信桥通信工程有限公司| 重庆鼎发实业有限公司| 有限公司 单位类型| 北方钢结构工程有限公司| 上海园林绿化有限公司地址| 深圳米珂拉服饰有限公司| 海正药业(杭州)有限公司| 意奔玛(苏州)有限公司| 合肥 景观设计有限公司| 太平保险有限公司陕西分公司| 金达五金制品有限公司招聘| 山西大唐新能源有限公司| 精宏仪器设备有限公司| 比锦味食品有限公司| 山东青岛机械有限公司| 雪华铃 深圳 有限公司| 泰森建设工程有限公司| 武汉鑫电力工程有限公司| 深圳星利电子有限公司| 泽顺机械制造有限公司| 安美达机械有限公司| 创全的发展有限公司| 天士力之骄药业有限公司| 涿州环保催化剂有限公司| 汇德发物资有限公司| 常州数控机械设备有限公司| 深圳博科瑞有限公司| 武汉邦迪管路系统有限公司| 西安电机制造有限公司| 余姚市橡胶制品有限公司| 顺德运动器材有限公司| 山东省食品有限公司招聘| 超硬工具上海有限公司| 宁波华翔汽车镜有限公司| 浙江众泰汽车有限公司| 源创环保设备有限公司| 爱德夏汽车零部件昆山有限公司| 广东万昌印刷有限公司| 信德塑料制品有限公司| 金华灵声电子有限公司| 青岛食品机械制造有限公司| 安吉汽车运输有限公司| 烟台冶金机械有限公司| 安徽圣翰医疗有限公司| 天河城百货有限公司| 重庆联庆仪表有限公司| 三星电子电脑苏州有限公司| 固科加固技术有限公司| 华日升反光材料有限公司| 金工铝门窗机械实业有限公司 | 快尚时装(广州)有限公司| 海外电国际贸易有限公司| 威迩徕德电力设备上海有限公司| 山西亚宝医药有限公司| 威尔凯电气有限公司| 深圳华映显示有限公司| 建邦国际贸易有限公司| 山东轩竹医药有限公司| 华工激光设备有限公司| 武汉史密斯挂车有限公司| 东方明珠置业有限公司| 海龙王泵业有限公司| 中农大生物有限公司| 华润置地西安有限公司| 沈阳平通高新技术有限公司| 北京甲骨文有限公司| 珠海五金机电有限公司| 迈凯实金属技术 苏州 有限公司| 上海永大电梯有限公司| 安徽深燃天然气有限公司| 冰熊专用汽车有限公司| 上海福基食品有限公司| 浙江海德曼机床有限公司| 罗曼照明工程有限公司| 宁波拖拉机有限公司| 北京中瑞有限公司怎么样 | 无锡市减速机有限公司| 成都恒瑞能源有限公司| 食品有限公司经销商| 得意精密电子苏州有限公司| 贵人鸟 厦门 有限公司| 金刚石电机有限公司| 深圳市智联技术有限公司| 华润沧州热电有限公司| 长兴未来发展有限公司| 深圳紫光照明技术有限公司| 普路通供应链有限公司| 青岛中科新材料有限公司| 德枫丹 青岛 机械有限公司| 杭州南方机电有限公司| 庆阳医疗器械有限公司| 鑫航电子(深圳)有限公司| 禾绿回转寿司饮食有限公司| 新华光矿山设备有限公司| 盛世达电子有限公司| 上海益盟技术有限公司| 贝洱汽车热系统有限公司| 顺德鼎业实业有限公司| 杭州金属回收有限公司| 重庆煤科院有限公司| 河南体育旅游发展有限公司| 北京建才信息技术有限公司| 常熟汽车配件 有限公司| 启明星电力有限公司| 福州塑料包装有限公司| 宁夏劳务派遣有限公司| 合润麟食品有限公司| 有限公司的主管部门| 重庆高强汽车钢有限公司| 嘉联恒进出口有限公司| 苏州茂森精艺金属有限公司| 南宁招商地产有限公司| 红旗电线电缆有限公司| 瑞得信息技术有限公司| 大连服装进出口有限公司| 北京金融租赁有限公司| 深圳鑫高电子有限公司| 自动化有限公司 气动| 上海英宇塑料有限公司| 华诚电力设备有限公司| 晋江市鞋机有限公司| 上海在利实业发展有限公司| 江苏塑胶制品有限公司| 济南三塑塑业有限公司| 常州大亚进出口有限公司| 乐清微电机有限公司| 超艺装饰工程有限公司| 河南核洁净技术有限公司| 荣成泽鹏食品有限公司| 江苏天诚线缆有限公司| 玛斯米亚上海有限公司| 武汉涂装工程有限公司| 山东电力建设工程有限公司| 丰联汽车销售有限公司| 广州 有限公司 中企动力| 重庆智翔铺道技术工程有限公司| 锦州天鹅焊材有限公司| 天津中怡设计有限公司| 深圳市六福珠宝有限公司| 广州友迪资讯有限公司| 无锡 艺术品有限公司| 佳瑞佳木业有限公司| 百斯特电梯有限公司| 长安福特汽车有限公司招聘| 博士达电子有限公司| 马钢(合肥)材料有限公司| 科贝隆机械有限公司| 中金时代深圳有限公司| 西安陕鼓动力有限公司| 大金氟涂料有限公司| 深圳市辉鹏达有限公司| 泰州中海油有限公司招聘| 佛山市中泰有限公司| 鼎辉有限公司怎么样| 绍兴联奥汽车有限公司| 营口电线电缆有限公司| 创科达电子有限公司| 捷必信息技术有限公司| 深圳市起重机械有限公司| tcl空调器(武汉)有限公司| 大同电工(苏州)有限公司| 硕丰农业发展有限公司| 北京优信拍有限公司| 北京金美仕贸易有限公司| 宝鸡专用汽车有限公司| 河南 复合肥 有限公司| 青岛方圆机械有限公司| 正宏塑料制品有限公司| 深圳达玩具有限公司| 郑东新区热电有限公司| 康臣化妆品有限公司| 一电电池技术有限公司| 沈阳东亿制造有限公司| 中创国际贸易有限公司| 合肥食品销售有限公司| 禾盛生物技术有限公司| 锐珂厦门医疗有限公司| 长沙餐具消毒有限公司| 湖南设备安装工程有限公司| 福瑞康食品有限公司| 深圳市瑞研有限公司| 苏州凯德机电有限公司| 通用电气水处理无锡有限公司 | 深圳市义嘉有限公司| 深圳市瑞达光电有限公司| 深圳市瑞信电子有限公司| 莆田 财务 有限公司| 劳士领汽车配件昆山有限公司 | 巨升进出口有限公司| 福州精细化工有限公司| 德尔福动力推进系统有限公司| 宁波佳比佳工贸有限公司| 嘉亿进出口有限公司| 祥瑞医疗器械有限公司| 搜讯信息技术有限公司| 易凯达电子有限公司| 鼎力自动化有限公司| 阜阳市贸易有限公司| 日照茶叶有限公司招聘| 华美建设工程有限公司| 恒安心相印纸制品有限公司| 阿科普机电工程有限公司| 枭龙汽车技术有限公司| 上海中邦斯瑞有限公司| 江苏苏凯泵业有限公司| 惠州tcl 照明电器有限公司| 杭州伟家纺有限公司| 优派电子(深圳)有限公司| 清江电机制造有限公司| 乐享家上海有限公司| 深圳诺金实业有限公司| 上海毅兴塑胶原料有限公司| 盈成油脂工业有限公司| 永嘉利食品有限公司.| 华三通信技术有限公司招聘| 苏州德高进出口有限公司| 康杰自动化有限公司| 河南办公机具有限公司| 邯郸鹏博有限公司招聘| 河南诚信工程有限公司|