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
)
大神我的问题很简单的
展开
 我来答
  • 你的回答被采纳后将获得:
  • 系统奖励15(财富值+成长值)+难题奖励10(财富值+成长值)+提问者悬赏15(财富值+成长值)
shanyuanzz
2014-12-16 · 超过31用户采纳过TA的回答
知道答主
回答量:43
采纳率:100%
帮助的人:33.1万
展开全部
其实你也知道不难,最好自己多学学,多练练
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;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xiangjuan314
2014-12-16 · TA获得超过3.3万个赞
知道大有可为答主
回答量:2.9万
采纳率:0%
帮助的人:3059万
展开全部
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;
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式