使用Liquibase标签将最大列值设置为序列起始值

14

我想知道是否有可能从某个表格中获取最大列值,并将其设置为起始序列值,而无需使用纯 SQL。以下代码不起作用:

   <property name="maxId" value="(select max(id)+1 from some_table)" dbms="h2,mysql,postgres"/>
   <changeSet author="author (generated)" id="1447943899053-1">
      <createSequence sequenceName="id_seq" startValue="${maxId}" incrementBy="1"/>
   </changeSet>

发生了错误:

Caused by: liquibase.parser.core.ParsedNodeException: java.lang.NumberFormatException: For input string: "${m"

我尝试过不在select ...等周围加上括号,结果相同。所以无法将计算值用作起始序列值?


1
对于Postgres,我能想到的唯一方法就是创建序列,然后使用<sql>标签运行select setval('id_seq', (select max(id)+1 from some_table)); - user330315
你能发布你的配置文件的其余部分吗?你在什么环境中使用liquibase? - Norbert
Norbert,Java8,Spring-boot 1.2.6,Liquibase 3.4.1,Postgres(9.3-1102-jdbc41)用于执行,H2用于测试。 - dfche
我尝试了以下内容: alter sequence user_id_seq restart with 333 alter sequence user_id_seq restart with (select max(id)+1 from jhi_user) H2可以正常工作。对于Postgres,“select setval(...)”不起作用,也不会“alter sequence ... restart with ...”。 - dfche
@a_horse_with_no_name 你的解决方案是对的,你可以把它发表为答案。我的所有问题都是因为在dbms标签中拼错了数据库名称。我最终实现了以下序列设置: <sql dbms="postgresql">select setval('user_id_seq', max(id)+1) from jhi_user</sql> <sql dbms="h2">alter sequence user_id_seq restart with (select max(id)+1 from jhi_user)</sql> - dfche
2个回答

9
所以,这样的解决方案对我很有效:
<changeSet author="dfche" id="1448634241199-1"> 
  <createSequence sequenceName="user_id_seq" startValue="1" incrementBy="1"/> 
</changeSet> 
<changeSet author="dfche" id="1448634241199-2">
  <sql dbms="postgresql">select setval('user_id_seq', max(id)+1) from jhi_user</sql> 
  <sql dbms="h2">alter sequence user_id_seq restart with (select max(id)+1 from jhi_user)</sql>
</changeSet>

0

对于PostgreSQL,正确的SQL DBMS语句是:

<sql dbms="postgresql">select setval('some_table_id_seq', (select max(id)+1 from some_table), false)</sql>

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接