当前位置:Gxlcms > 数据库问题 > ASP.NET Cache 实现依赖Oracle的缓存策略

ASP.NET Cache 实现依赖Oracle的缓存策略

时间:2021-07-01 10:21:17 帮助过:2人阅读

二、在Oracle数据库中创建触发器

  1、触发器被触发时执行PL/SQL代码块。PL/SQL代码块直接读写操作系统中的文件,需调用内置的utl_file程序包。这需要先修改Oracle的初始化参数文件INIT.ORA,在其中添加参数utl_file_dir,来指定文件的目录。修改INIT.ORA文件后,需重启Oracle数据库,设置的参数才能生效。

  在INIT.ORA文件中添加下面一行内容:

        utl_file_dir=‘E:/CSharp/CacheByOracleDependncy‘

  也可以设置为utl_file_dir=*,不指定具体目录,即任何目录都可以。

  如果是Oracle 9i数据库,还有一种方法也能起到同样的作用:在sys用户下创建一个directory目录(实际上是在sys用户下的dir$表中增加一个对应的OS_PATH),然后将对该directory对象的读/写操作的权限grant给public。

 

[sql] view plain copy  
  1. create or replace directory FILEPATH as ‘E:/CSharp/CacheByOracleDependncy‘;  
  2.   
  3. grant read on directory FILEPATH to public;  


        这里我使用的是第二种方法。

  2、为所依赖的表(SCOTT用户的DEPT表)创建一个触发器:当DEPT表中的数据更改后,触发器就会将当前系统时间写入TextFile.txt文件中。

 

 

[sql] view plain copy  
  1. CREATE OR REPLACE TRIGGER  
  2. "SCOTT"."TEST_CACHE_BY_ORACLE_DEPENDNCY" AFTER  
  3. INSERT  
  4. OR UPDATE  
  5. OR DELETE OF "DEPTNO", "DNAME", "LOC" ON "SCOTT"."DEPT" DECLARE  
  6. file_handle utl_file.file_type;  
  7. BEGIN  
  8. --打开文件  
  9. file_handle := utl_file.fopen(‘FILEPATH‘,‘TextFile.txt‘,‘w‘);  
  10. --将当前系统时间写入文件  
  11. IF utl_file.is_open(file_handle) THEN  
  12.  utl_file.put_line(file_handle,to_char(SYSDATE,‘yyyy-mm-dd hh24:mi:ss‘));  
  13. END IF;  
  14. --关闭文件  
  15. utl_file.fclose(file_handle);  
  16. EXCEPTION  
  17. WHEN OTHERS THEN  
  18. BEGIN  
  19. IF utl_file.is_open(file_handle) THEN  
  20. utl_file.fclose(file_handle);  
  21. END IF;  
  22. EXCEPTION  
  23. WHEN OTHERS THEN  
  24. NULL;  
  25. END;  
  26. END;  


如果应用服务器和数据库服务器不是同一台服务器可能会遇到项目无法成功访问文件进行依赖的情况:

 

解决方法详见ASP.NET访问网络驱动器(映射磁盘)

ASP.NET Cache 实现依赖Oracle的缓存策略

标签:

人气教程排行