在Oracle中模拟ms Sql 中的自动增加字段

在Oracle中模拟ms Sql 中的自动增加字段

方法原理:建立一个与表字段对应的序列,再建立一个插入前的触发器,使在插入前得到一个序列值,实现字段的自动增长列,不需手工干预。建立的触发器如下:

CREATE Or REPLACE TRIGGER 触发器名 before
        INSERT ON 表名
        FOR EACH ROW
BEGIN
        SELECT 序列名.NEXTVAL into :new.字段名 FROM dual;

       --IF :new.字段名 IS NULL THEN
        --    SELECT 序列名.NEXTVAL into :new.字段名 FROM dual;
       --END IF;
END;

经过以上的处理,这个字段将不接受手工值,如果想让字段在没有值的情况下才取序列值的话,请用下面注释掉的语句,即先判断一下,这个字段是否为null。

posted @   81  阅读(448)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
点击右上角即可分享
微信分享提示