1

我对一些mysql有一点问题。我会尽量提供更多的背景信息。情况就是这样,我为我父母的苗圃创建了一个可用性并将植物信息存储在 mysql 中,我第一次做得很糟糕,现在我正在用我同时获得的新知识重做它。

问题的背景,我在旧数据库中有 2 个表,其中一个被Gallery以下字段调用:

( id, Plant_id_1, Plant_id_2, Plant_id_3, Plant_id_4, Plant_id_5, Image1, Image1_Copyright, Image2, Image2_Copyright, Scientific, Common, Category, Height, Spread, Exposure, Zone, Descp)。

这些Plant_id_1...字段将是使用以下字段id调用的第二个表Availability的字段:

( id, name, size, description, available, upcomming, price)

如您所见,我对数据一无所知(仍然可能不知道),但对表的新结构一无所知,再次plants使用以下字段调用第一个表的 2 个表:

( id, scientific_name, common_name, category, height, spread, exposure, usda, description, image1_url, image1_copyright, image2_url, image2_copyright)

第二个current使用以下字段调用:

( id, plant_id, size, available, upcoming, price, description)

plant_id是表中相应植物的 id plant

现在谈谈这个问题。我需要从旧表中获取数据并将其放入新表中。我在新plant桌子上有画廊里的所有植物,那里没有问题。但现在要Availability进入Current表。

这是一个来自出口的例子Availability(我拿了前 3 名):

INSERT INTO `Availability` (`id`, `name`, `size`, `description`,`available`, `upcomming`, `price`) VALUES(91, 'Acer P.''Shishigashira''', ' #5', '30-36"', 27, 0, 36.00); 

INSERT INTO `Availability` (`id`, `name`, `size`, `description`, `available`,`upcomming`, `price`) VALUES(697, 'Arbutus U. ''Compacta''', ' #5','', 0, 0, 16.20); 

INSERT INTO `Availability` (`id`, `name`, `size`, `description`, `available`, `upcomming`, `price`) VALUES(90, 'Acer P.''Shigitatsusawa''', '#15', '', 0, 0, 65.00);

我需要plant_id从植物表中获取并将其放入插入语句中,我相信我有以下内容:

INSERT INTO `current` (`plant_id`, `size`,`description`, `available`, `upcoming`, `price`) VALUES(
(SELECT  `id` 
FROM  `plants` 
WHERE  `scientific_name` 
REGEXP  'Acer P.+ ''Shishigashira'''),  ' #5', '30-36"', 27, 0, 36.00);

但是现在我有一个新问题,如果plant表中没有匹配的植物怎么办,所以我需要一个 ifnull 在那里。用科学名称创建植物,其余为空。好吧,我是 SQL 新手,所以这就是我所拥有的,但它不起作用:

INSERT INTO `current` (`plant_id`, `size`,`description`, `available`, `upcoming`, `price`) VALUES(
(IFNULL( SELECT IFNULL( (SELECT `id` 
FROM  `plants` 
WHERE  `scientific_name` 
REGEXP  'Chamaecyparis O.+ Nana'),( 
INSERT INTO  `plants` (`scientific_name`)
VALUES (Chamaecyparis O. 'Nana'))))),  ' #1', '', 0, 0, 9.25);

如您所见,如果您认为自己能够应对帮助我的挑战,那将非常复杂,我将不胜感激。如果没有人可以帮助我,我将不得不手动将所有数据重新输入current表中。

4

1 回答 1

0

您应该努力选择返回您需要插入到新表中的数据。一旦你有了它,你可以简单地将它包装到一个 INSERT INTO - SELECT 构造中。这样您就不必导出和执行单独的插入。您可以一次简单地复制整个集合。

如果您确保当您将植物从画廊复制到植物表中时,id 保持不变,我希望这样的选择应该返回您要插入的行:

SELECT 
   Gallery.id as plant_id, 
   Availability.size, 
   Availability.available, 
   Availability.upcoming, 
   Availability.price,
   Availability.description
FROM Gallery 
INNER JOIN Availability
ON Gallery.Plant_id1 = Availability.id

然后你可以做同样的事情 5 次你改变

ON Gallery.Plant_id1 = Availability.id

到(一个接一个)

ON Gallery.Plant_id2 = Availability.id
ON Gallery.Plant_id3 = Availability.id
ON Gallery.Plant_id4 = Availability.id
ON Gallery.Plant_id5 = Availability.id

或者你把它们放在一个巨大的 sql 语句中,每个选择之间都有一个 UNION ALL

于 2011-08-31T17:03:23.327 回答