在mySQL中存储一个大数组

时间:2012-12-14 07:40:36

标签: mysql arrays store

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

第一个解决方案

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

或与foreach

第二个解决方案

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

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

2 个答案:

答案 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,...)]