oracle有没有自增长型,oracle如何实现自增长?

oracle如何实现自增长,有一个表:

CREATE TABLE `dutswitch` (

`ID` int(11) NOT NULL auto_increment,

`MachineName` varchar(20) NOT NULL,

`CustomerLotID` varchar(20) NOT NULL,

`state` varchar(4) NOT NULL,

`status1` varchar(64) NOT NULL,

`status2` varchar(64) NOT NULL,

`Date` varchar(20) NOT NULL,

PRIMARY KEY  (`ID`)

) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=7049 ;

插入一条数据:

INSERT INTO `dutswitch` VALUES (6903, 'xx-xx', 'F925547T0J', 'FT2', 'FFFF7EFFFFFFFFFFFFFFBFFFFFFFFFFFFFFC7FFCFFCFFFCF7FDF6FEEFFFFFFFF', '0', '20090830075545');

表中ID是自增长的,但是oracle中好像不支持自增长。现在我要插入一条数据,用oracle语法来写,但是不包含ID的内容,怎么才能成功写入?

insert into ('machinename','customerlotid','state','status1','status2','date') values (对应的变量);

------解决方法--------------------------------------------------------

oracle的资增长是通过SEQUENCE来实现的。

Create Sequence

你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限,

CREATE SEQUENCE emp_sequence

INCREMENT BY 1  -- 每次加几个

START WITH 1  -- 从1开始计数

NOMAXVALUE  -- 不设置最大值

NOCYCLE  -- 一直累加,不循环

CACHE 10;

一旦定义了emp_sequence,你就可以用CURRVAL,NEXTVAL

CURRVAL=返回 sequence的当前值

NEXTVAL=增加sequence的值,然后返回 sequence 值

比如:

emp_sequence.CURRVAL

emp_sequence.NEXTVAL

可以使用sequence的地方:

- 不包含子查询、snapshot、VIEW的 SELECT 语句

- INSERT语句的子查询中

- NSERT语句的VALUES中

- UPDATE 的 SET中

可以看如下例子:

INSERT INTO emp VALUES

(empseq.nextval, 'LEWIS', 'CLERK',7902, SYSDATE, 1200, NULL, 20);

SELECT empseq.currval  FROM DUAL;

ORACLE SEQUENCE 介绍

http://blog.csdn.net/tianlesoftware/archive/2009/10/30/4745039.aspx

------解决方法--------------------------------------------------------

oracle的资增长是通过SEQUENCE来实现的。

Create Sequence

你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限,

CREATE SEQUENCE emp_sequence

INCREMENT BY 1  -- 每次加几个

START WITH 1  -- 从1开始计数

NOMAXVALUE  -- 不设置最大值

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值