有人知道在插入、删除和更新操作后如何刷新表中的数据吗?我有一个简单的表格:
create table EV_JOURNAL (EVENT_TO_TASK_ID NUMBER(3)
NOT NULL Check(EVENT_TO_TASK_ID>0), EVENT_TIME TIMESTAMP WITH TIME ZONE NOT NULL);
已创建表我找到了一些关于触发器的信息,并编写了一个插入、删除和更新触发器后的信息:
create or replace
TRIGGER AFT_INS_UPD_DEL_TRIG
AFTER Insert or Delete or Update ON EV_JOURNAL
For Each Row
DECLARE
BEGIN
INSERT INTO EV_JOURNAL(EVENT_TO_TASK_ID,EVENT_TIME)
VALUES(:NEW.EVENT_TO_TASK_ID, :NEW.EVENT_TIME);
END AFT_INS_UPD_DEL_TRIG;
但是当我尝试将一些数据插入表中时,如下所示:
Insert into ev_journal (event_time,event_to_task_id) values(systimestamp,2);
我有以下错误:SQL 错误:ORA-04091:表 EV_JOURNAL 正在更改,触发器/函数可能看不到它;ORA-04088:执行触发器时出错;在这种情况下有人可以帮助我吗?我只需要刷新表,仅此而已,但我不知道该怎么做。
来自我的 c# 应用程序的代码,我需要在其中使用给定表中的刷新数据:
public static List<EventTrigger> FillEventTriggerList (List<EventTrigger> list)
{
using (OracleConnection connection = new OracleConnection (connectionString))
{
connection.Open ();
string sqlText = "Select * From EV_JOURNAL";
OracleCommand command = new OracleCommand (sqlText, connection);
OracleDataReader reader = command.ExecuteReader ();
while (reader.Read ())
{
list.Add (new EventTrigger (int.Parse(reader [ "EVENT_TO_TASK_ID" ].ToString()),(DateTime)(reader [ "EVENT_TIME" ])));
}
}
return list;
}
因此,当我假设从EV_JOURNAL中删除一些行时,在此选择查询之后,我得到必须已经删除的旧数据,但只有在我单击数据库中的刷新表后才会如此。
谢谢
这没有意义 - 您正在检测对表的更改,并尝试通过将相同的行插入同一表来响应。
也许您可以解释一下"刷新"表格的含义。
编辑:您不是在数据库中单击刷新,而是在访问数据库的某个工具中单击刷新。数据更改已经完成,但是无论您使用什么工具,都必须通过此单击被告知去阅读新版本。