动态创建VIEW
2014-08-25 23:20
127 查看
很多人都应该知道 global temporary table 的用法,这里也提出一个动态VIEW的用法,在实际过程中有着很好的独特之处
具体如下:
/***************创建PACKAGE ****************/
create or replace package p_view_temp_value is
g_org_id varchar2(60);
g_product_number varchar2(60);
g_dep_id varchar2(60);
procedure set_org_id(l_orgid varchar2,l_product_number varchar2,l_dept varchar2);
function get_id return varchar2;
function get_product return varchar2;
function get_dep_id return varchar2;
end p_view_temp_value;
/***************创建PACKAGE ****************/
create or replace package body p_view_temp_value Is
procedure set_org_id(l_orgid varchar2,l_product_number varchar2,l_dept varchar2) is
begin
g_org_id:=l_orgid;
g_product_number:=l_product_number;
g_dep_id:=l_dept;
end;
function get_id return varchar2 is
v_value varchar2(60);
begin
v_value:=g_org_id;
return v_value;
end;
function get_dep_id return varchar2 is
v_value varchar2(60);
begin
v_value:=g_dep_id;
return v_value;
end;
function get_product return varchar2 is
v_value varchar2(60);
begin
v_value:=g_product_number;
return v_value;
end;
end p_view_temp_value;
/****************创建动态视图******************/
create or replace view view_demo
(org_id,.....)
as
select org_id,......
from t_org_info where org_id=p_view_temp_value.get_id
;
注意此处的条件是利用PACKAGE的函数,这样可以达到条件的动态化,而且利用的PACK的特点,使这个试图的条件具有SESSION特性,
在执行此VIEW查询的时候,需要先执行 p_view_temp_value.set_org_id('001','','');
这样视图V_DEMO查询的就是 select org_id ... from t_org_info where org_id='001';
而且必须是在一个SESSION里,不同的SESSION查询出来的是不一样的,这也就说明了他的动态性,只要在不同的SESSION里就具有不同的结果集,这个特点跟GLOBAL TEMPORARY TABLE很类似
具体如下:
/***************创建PACKAGE ****************/
create or replace package p_view_temp_value is
g_org_id varchar2(60);
g_product_number varchar2(60);
g_dep_id varchar2(60);
procedure set_org_id(l_orgid varchar2,l_product_number varchar2,l_dept varchar2);
function get_id return varchar2;
function get_product return varchar2;
function get_dep_id return varchar2;
end p_view_temp_value;
/***************创建PACKAGE ****************/
create or replace package body p_view_temp_value Is
procedure set_org_id(l_orgid varchar2,l_product_number varchar2,l_dept varchar2) is
begin
g_org_id:=l_orgid;
g_product_number:=l_product_number;
g_dep_id:=l_dept;
end;
function get_id return varchar2 is
v_value varchar2(60);
begin
v_value:=g_org_id;
return v_value;
end;
function get_dep_id return varchar2 is
v_value varchar2(60);
begin
v_value:=g_dep_id;
return v_value;
end;
function get_product return varchar2 is
v_value varchar2(60);
begin
v_value:=g_product_number;
return v_value;
end;
end p_view_temp_value;
/****************创建动态视图******************/
create or replace view view_demo
(org_id,.....)
as
select org_id,......
from t_org_info where org_id=p_view_temp_value.get_id
;
注意此处的条件是利用PACKAGE的函数,这样可以达到条件的动态化,而且利用的PACK的特点,使这个试图的条件具有SESSION特性,
在执行此VIEW查询的时候,需要先执行 p_view_temp_value.set_org_id('001','','');
这样视图V_DEMO查询的就是 select org_id ... from t_org_info where org_id='001';
而且必须是在一个SESSION里,不同的SESSION查询出来的是不一样的,这也就说明了他的动态性,只要在不同的SESSION里就具有不同的结果集,这个特点跟GLOBAL TEMPORARY TABLE很类似
相关文章推荐
- Androidx学习笔记(22)-- 动态创建TextView展示数据库的数据
- ExtAspNet应用技巧(六) - ViewState与动态创建控件
- Androoid动态创建ImageView,设置间距方法
- Android 通过Java代码生成创建界面。动态生成View,动态设置View属性。addRules详解
- webView加载html动态创建标签
- 动态创建VIEW
- Android中如何在ViewPager中使动态创建的ImageView铺满屏幕
- 动态创建VIEW
- openerp创建动态视图-fields_view_get
- iOS tableView动态创建分组及组内排序
- [VC & MFC] 动态创建View的几个方法
- Android编程动态创建视图View的方法
- 创建动态用户控件和understanding viewstat
- Silverlight中如何自己写方法将DataTable转换为PagedCollectionView数据(动态创建类)
- ASP.NET AJAX Advance Tips & Tricks (2) 动态创建Rating控件不能保存ViewState的解决方案
- View 中动态创建自定义控件(参看图)
- 如何获得一个动态创建的textview的ID?
- 自定义ViewGroup实现标签换行(动态创建标签
- Android 通过Java代码生成创建界面。动态生成View,动态设置View属性。addRules详解
- ASP.NET 动态创建控件引起的ViewState读取问题