两个表,“用户”和“轨道”,我想为每个还没有的轨道创建一个用户(用户 ID = 0)。
我们没有用户所需的唯一电子邮件,因此旨在使用 generate_series 创建虚拟电子邮件:
insert into users (username, email)
select artist, (
select concat(generate_series(1, (SELECT COUNT(filename)
FROM tracks where userid = 0)),'@domain.com')
) as email
from tracks
where userid = 0
group by artist;
当然得到错误:
'ERROR: more than one row returned by a subquery used as an expression'
我可以使用两个 SQL 调用并让父代码 (Python) 执行循环,但我想正确的方法就是在 SQL 语句中。
那么如何使插入语句通过选择“循环”呢?
预期输出:
id | username | email
-----+-----------------------------------------------------------+-----------------------
62 | Sam Jackson | 1@infiniteglitch.net
63 | (unknown person) | 2@infiniteglitch.net
64 | Howard Cocel J. | 3@infiniteglitch.net