当前位置:首页 > 技术文章 > 正文内容

Mysql和Oracle实现序列自增(mysql自增序列函数)

zonemu2个月前 (08-05)技术文章42

Mysql和Oracle实现序列自增

/*ORACLE设置自增序列

oracle本身不支持如mysql的AUTO_INCREMENT自增方式,我们可以用序列加触发器的形式实现,

假如有一个表 T_WORKMATES,我们需要让学号PNO自增*/


--创建序列 SEQ_PNO


CREATE SEQUENCE SEQ_PNO

minvalue 1 --最小值为1

nomaxvalue --不设置最大值

START WITH 1 --从1开始计数

INCREMENT BY 1 --每次加1个

nocycle --一直累加,不循环

nocache;--不建缓冲区


--创建触发器TRI_PNO


CREATE

OR REPLACE TRIGGER TRI_PNO

BEFORE INSERT ON T_WORKMATES REFERENCING OLD AS OLD NEW AS NEW FOR EACH ROW

BEGIN

SELECT

SEQ_PNO.NEXTVAL INTO : NEW.PNO

FROM

DUAL;


END TRI_PNO;


---创建表


CREATE TABLE T_WORKMATES (

PNO INT ,

PNAME VARCHAR(100) NOT NULL,

PSEX VARCHAR(40)

) ;


--插入数据


INSERT INTO T_WORKMATES (PNO,PNAME,PSEX) VALUES ('','王盼东','男' ) ;

INSERT INTO T_WORKMATES (PNO,PNAME,PSEX) VALUES ('','刘德华','男' ) ;

INSERT INTO T_WORKMATES (PNO,PNAME,PSEX) VALUES ('','巩 俐','女' ) ;


--检查数据


SELECT * FROM T_WORKMATES ;


--删除一条数据并插入再重新检查


DELETE FROM T_WORKMATES T WHERE T.PNAME = '王盼东' ;

INSERT INTO T_WORKMATES (PNO,PNAME,PSEX) VALUES ('','王盼东','男' ) ;

SELECT * FROM T_WORKMATES ;



--我们发现删除再插入其序列还是一直增加的,这个是因为我们设置的序列只有自增功能,我们删除了数据并不影响序列的自增


/*mysql可以直接用AUTO_INCREMENT实现自增,方法如下*/

--创建数据表,对PNO序列进行自增

CREATE TABLE IF NOT EXISTS T_WORKMATES (

`PNO` INT UNSIGNED AUTO_INCREMENT,

`PNAME` VARCHAR(100) NOT NULL,

`PSEX` VARCHAR(40) NOT NULL,

PRIMARY KEY ( `PNO` )

) ENGINE=INNODB DEFAULT CHARSET=UTF8 ;


-- 插入数据

INSERT INTO T_WORKMATES ( PNAME , PSEX) VALUES ('王盼东','男');

INSERT INTO T_WORKMATES ( PNAME , PSEX) VALUES ('刘德华','男');

INSERT INTO T_WORKMATES ( PNAME , PSEX) VALUES ('巩 俐','女');

--查询插入数据

SELECT * FROM t_workmates ;

--删除一条数据并插入再次查询

DELETE FROM T_WORKMATES WHERE PNAME = '刘德华' ;

INSERT INTO T_WORKMATES ( PNAME , PSEX) VALUES ('刘德华','男');

SELECT * FROM T_WORKMATES ;




--我们发现删除再插入其序列还是一直增加的,这个是因为我们设置的序列只有自增功能,我们删除了数据并不影响序列的自增


Mysql 创建表的时候可以用IF NOT EXISTS 去查询是否有这个数据表,oracle也没有这个功能,我们也可以通过触发器去实现,这个下次再聊

相关文章

面试官:聊聊你知道的Vue与React的区别

最近面到很多大公司的时候,小编都会碰到一个很尴尬的问题,很多大公司的技术栈都是React,但是小编学的是Vue,其实从本质上来说两者都是比较优秀的前端框架,所以有些面试官会问到Vue和React的区别...

Vue基础(vue基础组件文件名符合规范的是)

Vue 是什么,它的核心特点有哪些?Vue 是一款渐进式 JavaScript 框架,它基于标准 HTML、CSS 和 JavaScript 构建,并提供了一套声明式的、组件化的编程模型,帮助开发者用...

「2022」打算跳槽涨薪,必问面试题及答案——VUE篇

1、为什么选择VUE,解决了什么问题?vue.js 正如官网所说的,是一套构建用户界面的渐进式框架。与其它重量级框架不同的是,vue 被设计为可以自底向上逐层应用。vue 的核心库只关注视图层,不仅易...

程序员项目经理如何调动组员积极性

#这个方法应该很适合程序员都说程序员是比较傲娇,有点小自负(有的是相当,那不叫自负,那是实力的体现好吗),略微呆萌,自尊心偏小强的一类族群。是吗?中招了吗?作为管理好几个组员,要完成一个大项目的项目经...

HTML5培训的学习大纲

第一阶段前端开发基础:1.HTML标签语言(xhtml+html5)行业介绍,本地环境配置,sublime编辑器学习使用,制作html标准模板,css基础,html常用标签(一),html常用标签(二...

在html5页面中如何使用vue3(html页面引入vue组件)

今天是2021.7.14,是个好日子.好久没发布文章了.今天发布下如何在在html页面中使用vue3.义县游学电子科技一直以技术文章为主.以下是h5的页面源码:<html><scri...