华为云云数据库GaussDBGlobal Plsql Cache特性函数_云淘科技

invalidate_plsql_object(); invalidate_plsql_object(schema, objname, objtype);

描述:将Global Plsql Cache全局缓存中的对象失效掉,仅在enable_global_plsqlcache = on时可用。调用该函数的用户需要具有SYSADMIN权限。

参数:该函数为重载函数。当无入参时,将所有database内的所有全局缓存对象失效。

当指定(schema, objname, objtype)三个参数时可将当前database内的指定全局缓存对象失效,其中:schema为对象所属的schema名称;objname为对象名称;objtype为对象类型,对象为package类型时值为’package’,对象为函数或存储过程时值为’function’。

示例:

该函数不返回失效结果,可通过gs_glc_memory_detail视图查询,对象未被失效时可在视图中查找到对应的valid状态的行,失效后则没有对应的valid状态行。

invalidate_plsql_object所属的schema为pg_catalog,但不指定schema也可调用该函数。

#如在视图中可查到函数f3的缓存信息,状态为valid
gaussdb=# select * from gs_glc_memory_detail where type='func' or type='pkg';
 contextname | database | schema  | type | status  |        location        |   env    | usedsize
-------------+----------+---------+------+---------+------------------------+----------+----------
 pkg1        | testdb | public  | pkg  | valid   | in_global_hash_table   |        0 |   184176
 f3          | testdb | public  | func | valid   | in_global_hash_table   |        0 |    47584
#调用函数,指定schema、函数名、类型即可将f3失效,再次查询视图,则f3没有对应的valid状态行
gaussdb=# select invalidate_plsql_object('public','f3','function');
 invalidate_plsql_object
-------------------------
(1 row)
#如要失效package类型,参数如下所示
gaussdb=# call pg_catalog.invalidate_plsql_object('public','pkg1','package');
 invalidate_plsql_object
-------------------------
(1 row)

#调用时没有入参,则将失效所有缓存对象
gaussdb=# select invalidate_plsql_object();
 invalidate_plsql_object
-------------------------
(1 row)

父主题: 函数和操作符

同意关联代理商云淘科技,购买华为云产品更优惠(QQ 78315851)

内容没看懂? 不太想学习?想快速解决? 有偿解决: 联系专家