Vous devez créer un nouvel ID pour la ligne nouvellement insérée :
INSERT INTO web_book(
id, page_count, year_published, file, image,
display_on_hp, name, description, name_cs,
name_en, description_cs, description_en
)
SELECT nextval('web_book_id_seq'),
page_count,
year_published,
file,
image,
display_on_hp,
name,
description,
name_cs,
name_en,
description_cs,
description_en
FROM web_book WHERE id=3;
Comme mentionné par ClodoaldoNeto, vous pouvez rendre les choses un peu plus faciles en omettant simplement la colonne ID et en laissant la définition par défaut faire son travail :
INSERT INTO web_book(
page_count, year_published, file, image,
display_on_hp, name, description, name_cs,
name_en, description_cs, description_en
)
SELECT page_count,
year_published,
file,
image,
display_on_hp,
name,
description,
name_cs,
name_en,
description_cs,
description_en
FROM web_book WHERE id=3;
Dans ce cas, vous n'avez pas besoin de connaître le nom de la séquence (mais ce qui se passe est un peu moins évident).