如何使用存储过程在mysql中选择和插入值

Posted

技术标签:

【中文标题】如何使用存储过程在mysql中选择和插入值【英文标题】:How to select and insert values in mysql using stored procedures 【发布时间】:2014-01-04 22:58:31 【问题描述】:

我是使用存储过程的新手。我有这个从表中获取值的查询。

之后,我需要将结果插入到另一个表中。

这是我的查询:

   SELECT a.gender, 
          b.purpose_abroad_as_per_recorded_travel, 
          b.country_name 
   FROM b   LEFT JOIN a
   ON b.person_id=a.id

我打算将所有结果插入到表“c”中。

如何使用存储过程同时进行选择和插入?谢谢

【问题讨论】:

【参考方案1】:

试试这个:

INSERT INTO c (gender, purpose_abroad_as_per_recorded_travel, country_name )
SELECT a.gender, b.purpose_abroad_as_per_recorded_travel, b.country_name 
FROM b 
LEFT JOIN a ON b.person_id = a.id;

【讨论】:

【参考方案2】:

可以将select返回的结果直接插入到insert中:

DELIMITER //
CREATE PROCEDURE updateTableC()
BEGIN       
       INSERT INTO c (gender, purpose_abroad_as_per_recorded_travel, country_name)
       SELECT a.gender, b.purpose_abroad_as_per_recorded_travel, b.country_name 
       FROM b   LEFT JOIN a
       ON b.person_id=a.id;
END//
DELIMITER ;

有关 mysql 存储过程的更多信息,这是一个好的开始:MySQL Stored Procedures 入门。

【讨论】:

以上是关于如何使用存储过程在mysql中选择和插入值的主要内容,如果未能解决你的问题,请参考以下文章

想使用存储过程在 mysql 数据库中插入值

我可以在存储过程中使用 if 语句将值插入到表中吗?

MySQL存储过程从列表中插入多行

MYSQL:存储过程,插入一行,然后通过 LAST_INSERT_ID() 选择它

在 PHP 中插入和从存储过程中选择

如何在sql创建一条插入数据的存储过程