网站首页 > 技术文章 正文
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也没有这个功能,我们也可以通过触发器去实现,这个下次再聊
猜你喜欢
- 2024-10-27 一文看懂mycat配置--数据库的读写分离、分表分库
- 2024-10-27 基于Percona XtraBackup 实现全备&增量备份与恢复
- 2024-10-27 Java EE核心框架实战:如何使用MyBatis实现CURD-2种数据库
- 2024-10-27 mysql如何进行累加计算 mysql 变量累加
- 2024-10-27 Springboot集成Mybatis ID生成策略注解 @GeneratedValue
- 2024-10-27 mybatis插入获取主键的方式和原理
- 2024-10-27 mybatis-plus保姆级入门教程,手把手教你轻松实现增删改查
- 2024-10-27 MyBatis框架 - 映射文件 mybatis如何映射表结构
- 2024-10-27 数据库操作语言SQL数据处理的增、查、删、改
- 2024-10-27 终于等到你:CYQ.Data V5系列 (ORM数据层)最新版本开源了
你 发表评论:
欢迎- 633℃几个Oracle空值处理函数 oracle处理null值的函数
- 626℃Oracle分析函数之Lag和Lead()使用
- 614℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 608℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 606℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 598℃【数据统计分析】详解Oracle分组函数之CUBE
- 588℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 572℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- oracle 19cOCM认证有哪些内容(oracle认证ocm月薪)
- Oracle新出AI课程认证,转型要持续学习
- oracle 表的查询join顺序,可能会影响查询效率
- Oracle DatabaseAmazon Web Services正式可用,Oracle数据库上云更容易了
- Oracle 19.28 RU 升级最佳实践指南
- 汉得信息:发布EBS系统安装启用JWS的高效解决方案
- 如何主导设计一个亿级高并发系统架构-数据存储架构(三)
- Java 后端开发必看!工厂设计模式轻松拿捏
- ORA-00600 「25027」 「x」报错(抱错孩子电视剧 爸爸是武术 另一个爸爸是画家)
- 新项目终于用上了jdk24(jdk新建项目)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)