如何使用存储过程在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中选择和插入值的主要内容,如果未能解决你的问题,请参考以下文章