我正在使用 Postgresql 和 PHP 5.3.x with PDO 来访问数据库。
我有这个SQL查询(剥离版本),有一个占位符供PDO填写:
INSERT INTO t_articles (a_article_id) VALUES (?) RETURNING a_id
我希望a_article_id
是一个数字,如5
,否则它应该是子查询的结果:
((SELECT max(a_article_id) FROM t_articles) + 1)
然而,PDO说:
SQLSTATE[22P02]: Invalid text representation: 7 ERROR: invalid input syntax for integer: "(SELECT max(a_article_id) FROM t_articles) + 1"
我试图将子查询设置为默认值,但显然不允许:
ERROR: cannot use sub query in default expression
如何插入此子查询的结果(或者可以采取哪些措施来实现相同的结果)?
答案 0 :(得分:9)
你必须使用INSERT ... SELECT:
insert into t_articles (a_article_id)
select max(a_article_id) + 1
from t_articles
returning id
如果您不需要a_article_id
的连续值,请使用sequence:
创建一个序列,我们称之为article_id_sequence
。
-- Get the current max(a_article_id)+1 to use instead of FIRST_VAL below
create sequence article_id_sequence
start FIRST_VAL
owned by t_articles.a_article_id;
将t_articles.a_article_id
的默认值设置为nextval('article_id_sequence')
。
alter table t_articles
alter column a_article_id
set default nextval('article_id_sequence');
插入时使用默认值:
insert into t_articles (a_article_id)
values (default)
returning id;