
oracle触发器在同一个表中增加一个生日字段时另一个年龄字段相应改变 15
大神???何在帮帮忙啊??实在是不会写oracle触发器,具体内容是这样的我的数据库有一张表我表里面的字段有4个字段id,name,bir_date,age但是我想每次我...
大神???何在帮帮忙啊??实在是不会写oracle触发器,具体内容是这样的
我的数据库有一张表 我表里面的字段有4个字段 id ,name, bir_date, age 但是我想每次我给表里插入数据的时候,我不想插入age,我只是插入其他3个字段(id,name,bir_date)让age自动相应的增加,更具触发器实现,age的值是年龄;其中 bir_date的类型是时间类型date,而age的类型是number;
例如:插入一条数据 insert into person(id,name,bir_date)values(1,'abc','12-15月-2004'); 然后age年龄的值自动变成10;我说的应该够详细了,希望大神们能帮助我写一个触发器啊???大神快来吧!!!!实在是感谢不尽啊!!!
这里附上建表语句:希望大神能懂我的意思!!!!
create table person
(
id number not null,
name varchar2(20),
bir_date date,
age number
)
大神我的问题很简单的 展开
我的数据库有一张表 我表里面的字段有4个字段 id ,name, bir_date, age 但是我想每次我给表里插入数据的时候,我不想插入age,我只是插入其他3个字段(id,name,bir_date)让age自动相应的增加,更具触发器实现,age的值是年龄;其中 bir_date的类型是时间类型date,而age的类型是number;
例如:插入一条数据 insert into person(id,name,bir_date)values(1,'abc','12-15月-2004'); 然后age年龄的值自动变成10;我说的应该够详细了,希望大神们能帮助我写一个触发器啊???大神快来吧!!!!实在是感谢不尽啊!!!
这里附上建表语句:希望大神能懂我的意思!!!!
create table person
(
id number not null,
name varchar2(20),
bir_date date,
age number
)
大神我的问题很简单的 展开
- 你的回答被采纳后将获得:
- 系统奖励15(财富值+成长值)+难题奖励10(财富值+成长值)+提问者悬赏15(财富值+成长值)
2个回答
展开全部
其实你也知道不难,最好自己多学学,多练练
So,我把表名换掉了,但是其他的没变,你改改表名,也当学习吧。
那个触发器里命名的变量可以不要,多写的。
create or replace trigger TRI_CUSTOMER
before insert on customer
REFERENCING OLD AS "OLD" NEW AS "NEW"
for each row
declare
v_age customer.age % type;
begin
SELECT Floor(months_between(SYSDATE, :new.bir_date)/12) INTO :new.age FROM DUAL ;
end TRI_CUSTOMER;
So,我把表名换掉了,但是其他的没变,你改改表名,也当学习吧。
那个触发器里命名的变量可以不要,多写的。
create or replace trigger TRI_CUSTOMER
before insert on customer
REFERENCING OLD AS "OLD" NEW AS "NEW"
for each row
declare
v_age customer.age % type;
begin
SELECT Floor(months_between(SYSDATE, :new.bir_date)/12) INTO :new.age FROM DUAL ;
end TRI_CUSTOMER;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
CREATE OR REPLACE TRIGGER person_insert
AFTER INSERT
ON person
REFERENCING NEW AS NEW OLD AS OLD
FOR EACH ROW
DECLARE
UCONT NUMBER;
BEGIN
SELECT COUNT(1) INTO UCONT FROM person WHERE id=:new.id OR name=:new.name OR bir_date=:new.bir_date;
if (QCOUNT>0)
then
Insert into person (age) Values (10);
end if;
end;
AFTER INSERT
ON person
REFERENCING NEW AS NEW OLD AS OLD
FOR EACH ROW
DECLARE
UCONT NUMBER;
BEGIN
SELECT COUNT(1) INTO UCONT FROM person WHERE id=:new.id OR name=:new.name OR bir_date=:new.bir_date;
if (QCOUNT>0)
then
Insert into person (age) Values (10);
end if;
end;
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询