Firebird的自增字段
在管理工具中直接设置为“auto”即可设置为自动增长字段。同时会创建一个序列值,如RDB$10,后面10会递加,若删除表,则这个序列也自动删除。但没有同时创建触发器。
auto功能相当于默认值,但在对象中未找到。
在insert表时,若此字段给值则用给定值,若没有才会调用序列的自增值。这带来一个问题:若手工给定一个值后,当后续不给值时,序列递增到此时会和手工值重复。
若是主键则会出错。
或重建表后,重新导入数据,这时自增序列当前值是1,则表中实际已有很多数据,这时需要查询表中的最大值,然后手工设定序列的当前值。
ALTER SEQUENCE RDB$1 RESTART WITH 10; //10是序列重新开始的序号,RDB$1是序列名
查询序列RDB$1下一个可用值(两种方法):
select next value for RDB$1 from rdb$database //每次默认加1
SELECT GEN_ID("RDB$1",2) FROM RDB$DATABASE; //第次加多少由参数设定,本语句中每次加2
创建:
CREATE SEQUENCE sss_name START WITH 0 INCREMENT BY 1;