将大型数组存储到mySQL数据库的最佳方法是什么?
第一个解决方案
INSERT INTO `friendList` ( `userId` , `friendId` , `friendName` ) VALUES
( '1', '3242343', 'bernd' ),
( '1', '3242342', 'jusu' );
或与foreach
第二个解决方案
foreach (xxxx) {
mysql_query("insert xxxx");
}
第一个解决方案更好(更干净,对服务器来说不那么繁琐,对吧?),但是如何创建这个插入命令呢?
答案 0 :(得分: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']));
}
答案 1 :(得分: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,...)]