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;

posted @   81  阅读(340)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
历史上的今天:
2014-07-29 修改Chrome临时文件位置
点击右上角即可分享
微信分享提示