oracle改mysql序列_oracle mysql的序列的新增、删除、修改及使用

方法一:

(1)删除序列;  (2)重新创建; 这个方法比较简单粗暴。

drop sequence  sequence_name;

create sequence   sequence_name

minvalue 1                                                             //最小值

maxvalue 999999999999999999999999999  //最大值

start with  10                                                         //初始值

increment by 1                                                     //步长

cache 20;                                                               //序列号缓存

方法二:

通过Increment By来实现修改初始值。

例如:若序列名称是seq_name,初始值是15,而现在要设置初始值为1015,Increment By值为:1000(1013-13)

1) 执行:alter sequence seq_name increment by 1000;

2) 执行:select seq_name .nextval from dual;

3) 执行:alter sequence seq_name increment by 1;

修改完成。

CREATE SEQUENCE [ schema. ]sequence

[ { INCREMENT BY | START WITH } integer

| { MAXVALUE integer | NOMAXVALUE }

| { MINVALUE integer | NOMINVALUE }

| { CYCLE | NOCYCLE }

| { CACHE integer | NOCACHE }

| { ORDER | NOORDER }

];

ALTER SEQUENCE [ schema. ]sequence

{ INCREMENT BY integer

| { MAXVALUE integer | NOMAXVALUE }

| { MINVALUE integer | NOMINVALUE }

| { CYCLE | NOCYCLE }

| { CACHE integer | NOCACHE }

| { ORDER | NOORDER }

};

1)结论一:在初创建的Sequence上第一次使用nextval的时候,得到是初始值,不是初始值加一!

2)结论二:第一次NEXTVAL初始化之后才能使用CURRVAL取值;

3)结论三:可以在一条SQL语句中同时得到nextval和currval值;

4)结论四:从上面的alter sequence的语法看,可以得到这样一个结论,无法使用alter语句修改序列的当前值。

使用(在插入语句中使用)

useGeneratedKeys="true" keyProperty="Id">

select SEQ_STUDENT_ID.nextval from dual

insert into student

ID,

NAME,

#{id,jdbcType=INTEGER},

#{name,jdbcType=INTEGER},

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值