请问这个行级触发器怎么写

puppylsy 2003-09-22 02:47:08
表1:Address 表2:Class 表3: (Address和Class的映射表)
AddressID(key) ClassID(key) AddressID
AddressName ClassName ClassID

表4:
AddressID(key)
AddressName
ClassName1
ClassName2

现在往表4中插入表1的数据,还希望插入ClassName1和ClassName2两个字段,这两个字段是表4的AddressID从表3映射表中查出来对应,前两个ClassID对应到表2的ClassName字段(如果没有两个就设为空),请问应该怎么写触发器,多谢!
...全文
59 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
puppylsy 2003-10-17
  • 打赏
  • 举报
回复
多谢各位大虾指点,再次向各位提供帮助的朋友和帮我顶的朋友致谢!
vrv0129 2003-09-25
  • 打赏
  • 举报
回复
up
DavidGu 2003-09-25
  • 打赏
  • 举报
回复
注意,你无法在一个表里插入记录时,再通过后台的TRIGGER来触发修改这个表的字段。因此,你只能在插入记录时,在前台同时完成相关字段的赋值。你可以在pre insert 事件完成下面的代码。
good luck!

DECLARE
n_temp number;
class_name1 YourType;
class_name2 YourType;
CURSOR class_name IS
SELECT a.ClassName FROM 表2 a,表3 b
WHERE a.ClassId=b.ClassId and b.AddressId=:new.AddressId;
begin
if inserting then
n_temp:=1
for RC in class_name loop
if n_temp=3 then
exit;
end if;
if n_temp=1 then
class_name1:=RC.ClassName;
end if;
if n_temp=2 then
class_name2:=RC.ClassName;
end if;

n_temp:=n_temp+1;
end loop;
ClassName1:=class_name1;
ClassName2:=class_name2;
end if;
end;
anne 2003-09-24
  • 打赏
  • 举报
回复
少FORM关键字。
anne 2003-09-24
  • 打赏
  • 举报
回复
楼上的哥们写错了。
anne 2003-09-24
  • 打赏
  • 举报
回复
请问楼主,建表3的时候根据什么条件?也就是AddressID和ClassID如何对应?
beckhambobo 2003-09-22
  • 打赏
  • 举报
回复
create or replace trigger sy
before insert on 表4
for each row
begin
select ClassName into
select (select ClassName from 表2 b where b.ClassID=C.ClassID) INTO :new.ClassName1 from 表3 c where AddressID=:new.AddressID;
end;
/
qiuyang_wang 2003-09-22
  • 打赏
  • 举报
回复
create or replace trigger sy befor insert on 表4 for each row
begin
select classNeme into :new.className1 from 表2
where classid =
(select classid from 表3
where addressid = :new.addressid and rownum <= 1);

select classNeme into :new.className2 from 表2
where classid =
(select classid from 表3
where addressid = :new.addressid and rownum <= 1
and classid <> :new.className1);

EXCEPTION
WHEN OTHERS THEN
null;
end;
内容概要:本文围绕基于三重移相控制(TPS)的双有源桥(DAB)高频隔离DC-DC变换器开展系统性研究,重点构建了其在Simulink环境下的高精度仿真模型。研究全面涵盖SPS单相移相、DPS双重重移相与TPS三重移相等多种控制策略的建模、实现与性能对比,深入分析不同模式下变换器的功率传输特性、软开关实现条件及功率回流问题,旨在提升DAB在交直流混合微电网、能量路由器、多端口柔性互联装置等场景中的转换效率与动态响应能力。通过对ZVS(零电压切换)条件的精确控制与移相角参数的优化,有效降低了开关损耗,增强了系统整体能效与运行稳定性。该仿真模型具有良好的可扩展性,适用于复杂电能转换系统的科研验证与工程开发。; 适合人群:电力电子、电气工程及其自动化等相关专业的硕士研究生、博士生、科研人员以及从事新能源变换器、柔性输配电系统设计的工程技术人员。; 使用场景及目标:①掌握双有源桥DAB变换器的基本工作原理及其在高频隔离场合的核心优势;②深入理解三重移相控制策略的设计机理、控制自由度分配及其在效率优化中的关键作用;③构建并调试可用于科研论文撰、项目申报或实际系统验证的高保真Simulink仿真模型,支撑理论分析与实验对比。; 阅读建议:建议结合MATLAB/Simulink平台进行动手实践,重点关注主电路拓扑搭建、移相控制模块设计、驱动信号时序配置及ZVS实现条件的仿真观测,推荐通过对比SPS、DPS与TPS三种模式的稳态与动态响应曲线,深入掌握各控制策略的适用边界与优化方向。
【重要提示】本资源设置为0积分下载,若非0积分请勿轻易下载 亲爱的CSDN用户: 首先感谢你点进这个资源页面。我需要提前说明一个重要情况: 本资源原本已设置为“0积分下载”,即作者希望完全免费共享。但CSDN平台有时会根据文件的下载热度、文件大小、用户权限等因素,自动将部分资源的积分调整为非0数值(如1积分、2积分、5积分等)。这是平台系统的自动行为,而非作者本人的设定。 因此,如果你当前看到该资源的下载所需积分不是0(例如显示为1、2、3……),请谨慎决定是否下载。 如果你按照非0积分支付并下载后发现资源内容不符合预期、链接失效,或者实际上该资源本应是免费的,作者无法为此承担积分损失或退还操作。强烈建议:仅在页面显示为0积分时进行下载。 另外,本资源描述中并未直接提供具体的下载地址或外部链接,因为它本身是一个通过CSDN官方上传通道提交的文件/内容包。如果你看到描述中没有外部网盘地址,这是正常的——资源文件应通过CSDN内置的“下载”按钮获取。若因平台积分显示异常导致你支付了积分,请优先联系CSDN客服咨询积分退还政策,作者没有权限修改平台自动设定的积分值。 感谢你的理解与支持。技术分享本应开放,但受限于平台规则,特此提醒如上。祝学习进步!

17,134

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧