删除或更新或插入刷新表后



有人知道在插入、删除和更新操作后如何刷新表中的数据吗?我有一个简单的表格:

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中删除一些行时,在此选择查询之后,我得到必须已经删除的旧数据,但只有在我单击数据库中的刷新表后才会如此。

谢谢

这没有意义 - 您正在检测对表的更改,并尝试通过将相同的行插入同一表来响应。

也许您可以解释一下"刷新"表格的含义。

编辑:您不是在数据库中单击刷新,而是在访问数据库的某个工具中单击刷新。数据更改已经完成,但是无论您使用什么工具,都必须通过此单击被告知去阅读新版本。

最新更新