0

将大数组存储到 mySQL DB 的最佳方法是什么?

第一个解决方案

INSERT INTO `friendList` ( `userId` , `friendId` , `friendName` ) VALUES 
    ( '1', '3242343', 'bernd' ), 
    ( '1', '3242342', 'jusu' );

或使用 foreach

第二种解决方案

foreach (xxxx) {
     mysql_query("insert xxxx");
}

第一个解决方案更好(更干净,对服务器来说不是那么繁琐,对吧?),但是如何创建这个插入命令呢?

4

2 回答 2

1

最快的方法是使用多重插入语法(如您所描述的),但这不是我向大多数人推荐的,除非性能真的很重要。您还需要注意不要超过最大查询大小(可以在服务器之间更改)。

但是,您可以使用准备好的语句(PDO 示例)来执行此操作,并且仍然可以获得合理的性能:

$db = new PDO($dsn, $user, $password, array(
    PDO::ATTR_EMULATE_PREPARES => false,
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
));

$stmt = $db->prepare('INSERT INTO `friendList` ( `userId` , `friendId` , `friendName` ) VALUES (?, ?, ?)');

foreach ($data as $row) {
    $stmt->execute(array($row['id'], $row['friendid'], $row['friendname']));
}
于 2012-12-14T07:48:57.823 回答
0

将所有数据存储在 csv 文件或文本文件中并使用LOAD DATA INFILE

LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE 'file_name.txt'
[REPLACE | IGNORE]
INTO TABLE tbl_name
[FIELDS
    [TERMINATED BY '\t']
    [[OPTIONALLY] ENCLOSED BY '']
    [ESCAPED BY '\\' ]
]
[LINES 
    [STARTING BY '']    
    [TERMINATED BY '\n']
]
[IGNORE number LINES]
[(col_name,...)]
于 2012-12-14T07:42:40.700 回答