您正在寻找的 SQL 模式是一对多的关系。它可以使用一张表将多个名称映射到一个 id:
Names
---------
Name VARCHAR(255) NOT NULL (Primary Key)
Id INT NOT NULL (Index)
您可以使用以下命令创建此表:
CREATE TABLE Names(
Name VARCHAR(255) NOT NULL,
Id INT NOT NULL,
PRIMARY KEY(`Name`),
INDEX `Id_idx` (`Id`)
);
然后,您可以使用以下方法将每个 id 的每个名称插入到数据库中:
INSERT INTO Names (Name, Id) VALUES('ABC', 109);
使用PDO 准备的查询,您可以执行以下操作:
$stmt = $dhb->prepare('INSERT INTO Names (Name, Id) VALUES(:name, :id)');
foreach($names as $nameStr) {
list($id, $name) = explode(' ', $nameStr); // split "109 ABC" into id: 109 and name: ABC
$stmt->execute(array(
':id' => $id,
':name' => $name
));
}
要检索索引的所有名称,您可以使用此 PDO 查询:
$id = 123;
$names = array();
$stmt = $dbh->prepare('SELECT Name FROM Names WHERE Id = :id');
$stmt->execute(array(':id' => $id));
while(($newName = $stmt->fetchColumn(0)) !== false) {
$names[] = $newName;
}