zoukankan      html  css  js  c++  java
  • Firebird的自增字段

    在管理工具中直接设置为“auto”即可设置为自动增长字段。同时会创建一个序列值,如RDB$10,后面10会递加,若删除表,则这个序列也自动删除。但没有同时创建触发器。

    在insert表时,若此字段给值则用给定值,若没有才会调用序列的自增值。这带来一个问题:若手工给定一个值后,当后续不给值时,序列递增到此时会和手工值重复。

    若是主键则会出错。

    或重建表后,重新导入数据,这时自增序列当前值是1,则表中实际已有很多数据,这时需要查询表中的最大值,然后手工设定序列的当前值。

    找到表对应的序列名,如下面的RDB$7, 122222表示一次增加的值,这样可以把序列的当前值改到表中的最大值

    SELECT  GEN_ID("RDB$7",122222)  FROM RDB$DATABASE;

  • 相关阅读:
    c++获取时间戳
    指针数组学习
    Matlab小波工具箱的使用2
    matlab 小波工具箱
    指针
    低通滤波参数
    git 合并分支到master
    matlab json文件解析 需要下载一个jsonlab-1.5
    matlab2017b
    数据结构-链式栈c++
  • 原文地址:https://www.cnblogs.com/81/p/15077686.html
Copyright © 2011-2022 走看看