ASPNET20实现依赖Oracle的缓

文章来源:丹阳文学网  |  2020-06-10

2.0中的缓存提供了对SQL依赖项的支持,也就是说当SQL SERVER数据库中的表或行中的数据被更改后,缓存中的页面就失效,否则,页面输出可一直保留在缓存当中。这确实为程序员提供了方便。但微软一向很小家子气,只为使用自家产品SQL SERVER的程序员提供了方便,那些用Oracle数据库的程序员怎么办呢?

其实不用着急,因为 2.0中的缓存还提供了对文件依赖项的支持,也就是缓存依赖于某个文件,该文件被修改后,缓存中的页面就失效。只要巧妙利用 2.0的文件依赖项缓存策略和Oracle中的触发器只能共进退。“人们普遍认为福利多多益善,就可轻松实现依赖Oracle的缓存策略。思路很简单,先将页面的缓存策略设置为依赖某一个文件,再为Oracle中需要依赖的表添加一个触发器,当表中的数据被更改时,修改缓存所依赖的文件中的内容。

下面以一个小例子来具体说明:

试验目的:px页面的缓存依赖于Oracle数据库中SCOTT用户的DEPT表,该表中数据被更改后,缓存中的页面失效。缓存的过期时间为120秒。

一、设置站页面的缓存依赖于文件t

1、打开Visual Studio 2005,在E:\CSharp\CacheByOracleDependncy目录下新建一个WEB项目,在其px页面上添加一个Label控件,显示页面生成的时间,以判断刷新时页面是否为重新生成的,并设置页面缓存依赖于文件E:\CSharp\CacheByOracleDependncy\t。

protected void Page_Load(object sender, EventArgs e)

{

//显示当前时间,以便判断是否为缓存中页面

xt = "CacheByOracleDependency:" + String();

//缓存依赖于文件t

string fileDependencyPath = pPath("t");

dFileDependency(fileDependencyPath);

// 设置缓存的过期时间为120秒。

tExpires(dSeconds(120));

tCacheability(blic);

tValidUntilExpires(true);

}

2、在E:\CSharp\CacheByOracleDependncy目录下新建一个t文件。

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

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

在A文件中添加下面一行内容:

utl_file_dir='E:\CSharp\CacheByOracleDependncy'

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

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

create or replace directory FILEPATH as 'E:\CSharp\CacheByOracleDependncy';

grant read on directory FILEPATH to public;

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

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

CREATE OR REPLACE TRIGGER

"SCOTT"."TEST_CACHE_BY_ORACLE_DEPENDNCY" AFTER

INSERT

OR UPDATE

OR DELETE OF "DEPTNO", "DNAME", "LOC" ON "SCOTT"."DEPT" DECLARE

file_handle utl_le_type;

BEGIN

--打开文件

file_handle := utl_pen('FILEPATH','t','w');

--将当前系统时间写入文件

IF utl__open(file_handle) THEN

utl_t_line(file_handle,to_char(SYSDATE,'yyyy-mm-dd hh24:mi:ss'));

END IF;

--关闭文件

utl_lose(file_handle);

EXCEPTION

WHEN OTHERS THEN

BEGIN

IF utl__open(file_handle) THEN

utl_lose(file_handle);

END IF;

EXCEPTION

WHEN OTHERS THEN

NULL;

END;

END;

三、测试

前面两步完成后,依赖Oracle的缓存策略就设置好了。只要DEPT表中的数据更改后,触发器就会修改t文件中的内容,t文件一被修改,缓存中的页面就自动失效了,再次访问页面时,请求就会发给服务器,来重新生成页面。

在Visual Studio 2005中调试程序,不断刷新打开的px页面,页面显示的时间每隔120秒,才会发生变化一次。这是因为设置的缓存过期时间为120秒。这时,只要我们手工修改SCOTT用户的DEPT表中的数据后,再次刷新页面时,页面上显示的时间马上就会发生变化。这说明我们设置的依赖Oracle的缓存策略成功了。查看本文来源

白带色黄选什么妇科经典药
焦作白癜风医院
脑梗死如何恢复
友情链接