oracle 没有主键的表,添加主键并且给主键赋值

1. 添加主键(不标记主键、可以为空)
ALTER TABLE "LSJ_SERVER"."BASE_DRIVER_TRUCK" 
ADD ("ID" NUMBER);

COMMENT ON COLUMN "LSJ_SERVER"."BASE_DRIVER_TRUCK"."ID" IS '主键'
2. 更新ID的值
UPDATE BASE_DRIVER_TRUCK SET ID = rownum;
3. 设置主键
ALTER TABLE "LSJ_SERVER"."BASE_DRIVER_TRUCK" 
MODIFY ("ID"  NOT NULL);

ALTER TABLE "LSJ_SERVER"."BASE_DRIVER_TRUCK" ADD PRIMARY KEY ("ID");
4. 设置自增主键的值

创建
START WITH :开始的值 取决 更新ID的值 后的最大的ID的值+n即可

SELECT MAX(ID) FROM BASE_DRIVER_TRUCK 

INCREMENT : 增量

 CREATE SEQUENCE my_sequence
START WITH 100000
INCREMENT BY 1
NOCACHE;

删除

DROP SEQUENCE my_sequence;
5. 添加触发器
CREATE OR REPLACE TRIGGER BASE_DRIVER_TRUCK_trigger_ID
BEFORE INSERT ON BASE_DRIVER_TRUCK
FOR EACH ROW
BEGIN
    SELECT my_sequence.NEXTVAL
    INTO :new.ID
    FROM dual;
END;
添加数据,完成。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值