8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

SQL Oracle 序列不是从 1 开始的?

Konrad Rudolph 3月前

44 0

创建了一个带有序列的患者表:CREATE SEQUENCE Pt_ID_SEQINCREMENT BY 1START WITH 1NOMAXVALUEMINVALUE 1NOCACHE;在向患者表插入 10 行后,我确实从患者中选择了*……

创建了一个具有序列的患者表:CREATE SEQUENCE Pt_ID_SEQINCREMENT BY 1START WITH 1NOMAXVALUEMINVALUE 1NOCACHE;

在患者表中插入 10 行后,我确实从患者中选择了*以查看结果。第一个 Pt_ID 是 31!我该如何解决这个问题,以便插入的第一个患者是患者 1?

尝试删除所有序列、删除所有表并重新启动 SQL。每次我尝试填充患者表时,起始数字都会以 10 为单位不断增大(现在患者 1 的 pt_ID 为 41)。

帖子版权声明 1、本帖标题:SQL Oracle 序列不是从 1 开始的?
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由Konrad Rudolph在本站《sql》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 这不是答案,但是为什么需要从 1 开始的序列,假设每个新值都是唯一的并且通常会增加?

  • 如果没有真正充分而紧急的理由(有人告诉你这样做根本不是理由),请摆脱那些过时的序列。在某些情况下,Oracle 只是过时且缓慢(另请参见之前这么多年一直需要使用双表,你终于可以跳过它了)。这就是为什么他们使用序列这么长时间的原因。使用身份要简单得多,它们将从 1 开始。只需写

返回
作者最近主题: