Form开发常用语法
---on-log
触发器编写示范
Declare
flag varchar2(80):=null;
cou number:=1;
n number;
Begin
Loop
logon(USERNAME,PASSWORD||'@'||CONNECT,PROPERTY_FALSE....);
flag:=Get_Application_Property(DATASOURCE);
Exit when cou>8 or flag='ORACLE';
cou:=cou+1;
End Loop;
If flag<>'ORACLE' then
set_alert_property('a_1',alert_message_text,
' 登录失败, 请返回重试');
n:=show_alert('a_1');
raise form_trigger_failure; -- 中断 FORM
End if;
End;
--- 对基表执行查询( 只对基表)
Set_Block_Property('Block_Name',Default_Where,'where ......');
Go_Block('Block_Name');
Execute_Query;
***************************************************
变量:
局部变量;
全局变量--------------1.:block.item
2.:parameter.v_name
3.: global.V_name
***************************************************
--- 同步发生显示
synchronize;
--- 实施'TRIGGER' 触发
EXECUTE_TRIGGER(TRIGGER_NAME);
--- 清除模块
clear_block(NO_VALIDATE); 'NO_VALIDATE' 不生效
-- 建立警告栏并由警告栏选择
Declare
n number;
Begin
Set_Alert_Property('Alert_Name',Alert_Message_Text,'message');
n:=Show_Alert('Alert_Name');
If n=Alert_Button1 then
...;
ElsIf n=Alert_Button2 then
...;
End if;
End;
---WINDOW 设置
-- 运行时最大化, 最小化
Set_Window_Property(FORMS_MDI_WINDOW, WINDOW_STATE, MAXIMIZE|MINIMIZE);
--WINDOW 标题
Set_Window_Property(FORMS_MDI_WINDOW, title,'TEXT');
-- 退出是否为真
Set_Window_Property(FORMS_MDI_WINDOW, REMOVE_ON_EXIT,PROPERTY_FALSE|TRUE);
--- 设置系统提示信息等级
:System.Message_Level:= '5|10|15|20';
--- 设置ITEM 属性
-- 设置ITEM 属性ENABLED
Set_Item_Property('Block_name.Item_name',ENABLED,PROPERTY_TRUE|FALSE);
-- 设置ITEM 属性NAVIGABLE
Set_Item_Property('Block_name.Item_name',NAVIGABLE,PROPERTY_TRUE|FALSE);
-- 设置ITEM 属性VISUAL_ATTRIBUTE
Set_Item_Property('Block_name.Item_name',visual_attribute,'vname');
--'vname' 由导航器中(VISUAL_ATTRIBUTES) 定义
-- 设置ITEM 属性DISPLAYED
Set_Item_Property('Block_name.Item_name',displayed,TRUE|FALSE);
-- 设置ITEM 属性POSITION
Set_Item_Property('Block_name.Item_name',position,x,y);
-- 设置ITEM_SIZE
Set_Item_Property('Block_name.Item_name',item_size,x,y);
-- 设置ITEM 属性LABLE
Set_Item_Property('Block_name.Item_name',LABEL,'MESSAGE')
--- 设置LIST ITEM 示范
Declare
n number;
Begin
clear_list('b1.fkfs');
m:=populate_group('fkfs');
populate_list('b1.fkfs','fkfs');
End;
--- 增加'LIST ITEM'
Add_List_Element(list_name, list_index, list_label, list_value);
Add_List_Element(list_id, list_index, list_label, list_value);
--- 删除'LIST ITEM' 项
Delete_List_Element(list_name, list_index);
Delete_List_Element(list_id, list_index);
例:
BEGIN
Delete_List_Element('years',1);
Add_List_Element('years', 1, '1994', '1994');
END;
--- 获得'LIST ITEM' 项的组成
1. 获得'LIST ITEM' 的总和
GET_LIST_ELEMENT_COUNT(list_id);
GET_LIST_ELEMENT_COUNT(list_name);
2. 获得'LIST ITEM' 的标签
GET_LIST_ELEMENT_LABEL(list_id, list_name, list_index);
GET_LIST_ELEMENT_LABEL(list_name, list_index);
3. 获得'LIST ITEM' 的值
GET_LIST_ELEMENT_VALUE(list_id, list_index);
GET_LIST_ELEMENT_VALUE(list_name, list_index);
--- 设置' 时间'
DECLARE
timer_id Timer;
one_minute NUMBER(5) := 60000;
BEGIN
timer_id := CREATE_TIMER('emp_timer', one_minute, REPEAT|NO_REPEAT);
END;
--- 产生一个'EDITER' 框
DECLARE
ed_id Editor;
status BOOLEAN;
BEGIN
ed_id:=Find_Editor('edit_name'); --- 由'edit_name' 导航器定义
IF NOT Id_Null(ed_id) THEN
Show_Editor(ed_id, NULL, :block_name.item_name, status);
ELSE
Message('Editor "Happy_Edit_Window" not found');
RAISE Form_Trigger_Failure;
END IF;
END;
---- 产生一个'LOV' 框
DECLARE
lv_id LOV;
status BOOLEAN;
BEGIN
lv_id := Find_LOV('lov_name'); ---'lov_name' 由导航器定义
-- IF Id_Null(lv_id) THEN
-- lv_id := Find_LOV('lov_name1'); ---'lov_name1' 由导航器定义
-- END IF;
status := Show_LOV(lv_id,10,20);
END;
--- 定义一个'EXCEPTION' 例外
Declare
err_1 exception;
Begin
If ... then
Raise err-1;
End if;
Exception
When err_1 then
....
END;
--- 设置应用特性( 光标类型)
SET_APPLICATION_PROPERTY(CURSOR_STYLE,
'CROSSHAIR'|'BUSY'|'HELP'|'DEFAULT'|'INSERTION');
***********************************************************************
********************************** 函数*********************************
--- 把字符串的字符变成全大写(UPPER) 全小写(LOWER) 第一个字母大写(INITCAP)
UPPER|LOWER|INITCAP(STRING)
--- 在文件的左('LPAD') 右('RPAD') 粘贴字符
LPAD|RPAD(STRING,LENGTH,'SET') "LENGTH" 为总字符长"SET" 为粘贴字符
--- 在文件的左('LTRIM') 右('RTRIM') 删除字符
LTRIM|RTRIM(SRTING,'SET') "SET" 为待删除字符
--- 找出' 字符集' 在字符串中的位置
INSTR('STRING','SET',N,M) 从'STRING' 中找出'SET' 从'N' 位起第'M' 个
--- 数的绝对值
ABS(VALUE)
---'MOD' 模
MOD(VALUE, 除数) 返回' 除数' 除'VALUE' 的余数常用判断'VALUE' 是否为整数
--- 把'VALUE' 从'N' 位四舍五入'ROUND' 或从'N' 位截断'TRUNC'
ROUND|TRUNC(VALUE,N)
--- 返回'VALUE' 的符号
SIGN(VALUE)
--- 列表的最大值
GREATEST(N1,N1...);
列表的最小值
LEAST(N1,N1...);
--- 返回小于或等于数的最大整数
FLOOR(VALUE) floor(1.3)=1 floor(-1.3)=-2
--- 返回大于或等于数的最小整数
CEIL(VALUE) cell (1.3)=2 cell (-1.3)=-1
--- 取字符串长度
substr(string,start,number) number 为string 长度,start 为string 起点
---DECODE 函数, 多重(if,then,else)
decode(value,if1,then1,if2,then2,.....,else)
--- 判断'VALUE' 是否为空( 空值替换)
NVL(UALUE,'WKFHZ') 'WKFHZ' 是为空返回值, 不为空则为原值
--- 字段长度
length(:block_name.item_id)
--- 返回字符串的第一( 最左) 个字符的ascII 值
ascII(string)
--- 多行'VALUE' 的 ( 作用于多' 行')
AVG(VALUE) 平均值
COUNT(VALUE) 行数
MAX(VALUE) 最大值
MIN(VALUE) 最小值
SUM(VALUE) 和
--- 字符转换
TRANSLATE(STRING,' 待转字符',' 转换字符');
如 TEANSLATE('AAABBB','AB','BA') 返回'BBBAAA'
--- 比较单行中多个列的值获得最大('GREATEST' 最小('LEAST')
GREATEST|LEAST( 列名, 列名,...)
--- 按表达式或位置排序
ORDER BY ' 表达式'OR' 位置' ASC|DESC ASC' 升',DESC' 降' 默认'ASC'
***********************************************************************
***********************************************************************
--- 游标的属性
(1) %ISOPEN 打开属性
布尔型
打开为TRUE
判断' 光标' 是否打开如未打开则打开' 光标'
IF NOT(CORSOR_NAME%ISOPEN) THEN
OPEN CORSOR_NAME;
END IF;
FETCH CORSOR_NAME INTO ...
(2) %NOTFOUND 布尔型
最近一次'FETCH' 返回无结果
则为TRUE
OPEN CORSOR_NAME;
LOOP
FETCH CORSOR_NAME INTO ...
EXIT WHEN CORSOR_NAEM%NOTFOUND;
END LOOP;
(3) %FOUND 布尔型
最近一次'FETCH' 返回无结果
则为FALSE
OPEN CORSOR_NAME;
WHILE CORSOR_NAME%FOUND LOOP
......
FETCH CORSOR_NAME INTO ...
END LOOP;
CLOSE CORSOR_NAME;
(4) %ROWCOUNT NUMVER 型
为游标取出的行数
OPEN CORSOR_NAME;
LOOP
FETCH CORSOR_NAME INTO ...
EXIT WHEN CORSOR_NAME%ROWCOUNT>5;
......
END LOOP;
CLOSE CORSOR_NAME;
--- 循环语句
(1) 基本循环
LOOP
.....
EXIT WHILE; 如(EXIT WHEN X>100)
END LOOP;
(2)WHILE 循环
WHILE 如( WHEN X>100) LOOP
.....
END LOOP;
(3) 数值型FOR 循环 'X' 为计数器
FOR X IN ( 第减值) Y..Z LOOP
.....
END LOOP;
(4) 游标FOR 循环
---Exception( 例外) 在最近的'BEGIN' 和'END' 之间
Exception
语法1 当' 没有数据找到' 时
when no_data_found then
语法2 当' 发生任何错误' 时
when others then
语法3 当' 发现多行' 时
WHEN TOO_MANY_ROWS THEN
语法4 当' 字符向数字转换失败' 时
WHEN INVALID_NUMBER THEN
语法5 当' 被零除' 时
WHEN ZERO_DIVIDE THEN
语法6 当' 向唯一索引中插入重复数据' 时
WHEN DUP_VAL_ON_INDEX THEN
语法7 当' 非法游标操作' 时
WHEN INVALID_CURSOR THEN
语法8 当' 数字的, 数据转换, 截字符串或强制性的错误' 时
WHEN VALUE_ERROR THEN
**************************************************************************
**************************************************************************
-- 常用TEXT_IO
Delcare
out_file text_io.file_type;
Begin
out_file:=text_io.fopen('prn','w');
text_io.new_line(out_file,' ');
text_io.put_line(out_file,' ')
text_io.fclose(out_file);
End;
--- 文本输入输出
TEXT_IO
TEXT_IO PACKAGE
TEXT_IO FCLOSE
TEXT_IO.FILE_TYPE
TEXT_IO.FOPEN
TEXT_IO.IS_OPEN
TEXT_IO.GET_LINE
TEXT_IO.NEW_LINE
TEXT_IO.PUT
TEXT_IO.PUTF
TEXT_IO.PUT_LINE
USING TEXT_IO CONSTRUCTS
----------------------------
Declare
Out_file Text_io.file_type;
L Varchar2(100);
L1 Varchar2(100);
L2 Varchar2(100);
Begin
Out_file :=text_io.fopen('c:lllogin.txt','r');
If text_io.is_open(Out_file) then
text_io.get_line(Out_file,L);
text_io.get_line(Out_file,L1);
text_io.get_line(Out_file,L2);
Else
Null;
End if;
End;
--- 清除全局变量
erase('global.var_name');
--- 隐藏'WINDOW','VIEW','MENU'
HIDE_WINDOW|VIEW|MENU(WINDOW|VIEW|MENU_name);
--- 增加参数add_parameter
Declare
pl_id ParamList;
BEGIN
pl_id:=Get_Parameter_List('tempdata');
IF NOT Id_Null(pl_id) THEN
Destroy_Parameter_List(pl_id);
END IF;
pl_id:=Create_Parameter_List('tempdata');
Add_Parameter(pl_id,'EMP_QUERY',DATA_PARAMETER,'EMP_RECS');
Run_Product(REPORTS,'emp report',SYNCHRONOUS,RUNTIME,
FILESYSTEM,pl_id,NULL);
END;
---
DECLARE
lArgs OLE2.LIST_TYPE;
BEGIN
word.hApp:=OLE2.CREATE_OBJ('Word.Basic');
lArgs:=OLE2.CREATE_ARGLIST;
OLE2.ADD_ARG(lArgs, le.word_doc);
OLE2.INVOKE(Word.hApp,'fileopen',lArgs);
OLE2.DESTROY_ARGLIST(lArgs);
END;
*********************** 删除重复记录**************
Delete from emp e
where e.rowid >
(select min(f.rowid) from emp f
4 where f.empno=e.empno);
Declare
flag varchar2(80):=null;
cou number:=1;
n number;
Begin
Loop
logon(USERNAME,PASSWORD||'@'||CONNECT,PROPERTY_FALSE....);
flag:=Get_Application_Property(DATASOURCE);
Exit when cou>8 or flag='ORACLE';
cou:=cou+1;
End Loop;
If flag<>'ORACLE' then
set_alert_property('a_1',alert_message_text,
' 登录失败, 请返回重试');
n:=show_alert('a_1');
raise form_trigger_failure; -- 中断 FORM
End if;
End;
--- 对基表执行查询( 只对基表)
Set_Block_Property('Block_Name',Default_Where,'where ......');
Go_Block('Block_Name');
Execute_Query;
***************************************************
变量:
局部变量;
全局变量--------------1.:block.item
2.:parameter.v_name
3.: global.V_name
***************************************************
--- 同步发生显示
synchronize;
--- 实施'TRIGGER' 触发
EXECUTE_TRIGGER(TRIGGER_NAME);
--- 清除模块
clear_block(NO_VALIDATE); 'NO_VALIDATE' 不生效
-- 建立警告栏并由警告栏选择
Declare
n number;
Begin
Set_Alert_Property('Alert_Name',Alert_Message_Text,'message');
n:=Show_Alert('Alert_Name');
If n=Alert_Button1 then
...;
ElsIf n=Alert_Button2 then
...;
End if;
End;
---WINDOW 设置
-- 运行时最大化, 最小化
Set_Window_Property(FORMS_MDI_WINDOW, WINDOW_STATE, MAXIMIZE|MINIMIZE);
--WINDOW 标题
Set_Window_Property(FORMS_MDI_WINDOW, title,'TEXT');
-- 退出是否为真
Set_Window_Property(FORMS_MDI_WINDOW, REMOVE_ON_EXIT,PROPERTY_FALSE|TRUE);
--- 设置系统提示信息等级
:System.Message_Level:= '5|10|15|20';
--- 设置ITEM 属性
-- 设置ITEM 属性ENABLED
Set_Item_Property('Block_name.Item_name',ENABLED,PROPERTY_TRUE|FALSE);
-- 设置ITEM 属性NAVIGABLE
Set_Item_Property('Block_name.Item_name',NAVIGABLE,PROPERTY_TRUE|FALSE);
-- 设置ITEM 属性VISUAL_ATTRIBUTE
Set_Item_Property('Block_name.Item_name',visual_attribute,'vname');
--'vname' 由导航器中(VISUAL_ATTRIBUTES) 定义
-- 设置ITEM 属性DISPLAYED
Set_Item_Property('Block_name.Item_name',displayed,TRUE|FALSE);
-- 设置ITEM 属性POSITION
Set_Item_Property('Block_name.Item_name',position,x,y);
-- 设置ITEM_SIZE
Set_Item_Property('Block_name.Item_name',item_size,x,y);
-- 设置ITEM 属性LABLE
Set_Item_Property('Block_name.Item_name',LABEL,'MESSAGE')
--- 设置LIST ITEM 示范
Declare
n number;
Begin
clear_list('b1.fkfs');
m:=populate_group('fkfs');
populate_list('b1.fkfs','fkfs');
End;
--- 增加'LIST ITEM'
Add_List_Element(list_name, list_index, list_label, list_value);
Add_List_Element(list_id, list_index, list_label, list_value);
--- 删除'LIST ITEM' 项
Delete_List_Element(list_name, list_index);
Delete_List_Element(list_id, list_index);
例:
BEGIN
Delete_List_Element('years',1);
Add_List_Element('years', 1, '1994', '1994');
END;
--- 获得'LIST ITEM' 项的组成
1. 获得'LIST ITEM' 的总和
GET_LIST_ELEMENT_COUNT(list_id);
GET_LIST_ELEMENT_COUNT(list_name);
2. 获得'LIST ITEM' 的标签
GET_LIST_ELEMENT_LABEL(list_id, list_name, list_index);
GET_LIST_ELEMENT_LABEL(list_name, list_index);
3. 获得'LIST ITEM' 的值
GET_LIST_ELEMENT_VALUE(list_id, list_index);
GET_LIST_ELEMENT_VALUE(list_name, list_index);
--- 设置' 时间'
DECLARE
timer_id Timer;
one_minute NUMBER(5) := 60000;
BEGIN
timer_id := CREATE_TIMER('emp_timer', one_minute, REPEAT|NO_REPEAT);
END;
--- 产生一个'EDITER' 框
DECLARE
ed_id Editor;
status BOOLEAN;
BEGIN
ed_id:=Find_Editor('edit_name'); --- 由'edit_name' 导航器定义
IF NOT Id_Null(ed_id) THEN
Show_Editor(ed_id, NULL, :block_name.item_name, status);
ELSE
Message('Editor "Happy_Edit_Window" not found');
RAISE Form_Trigger_Failure;
END IF;
END;
---- 产生一个'LOV' 框
DECLARE
lv_id LOV;
status BOOLEAN;
BEGIN
lv_id := Find_LOV('lov_name'); ---'lov_name' 由导航器定义
-- IF Id_Null(lv_id) THEN
-- lv_id := Find_LOV('lov_name1'); ---'lov_name1' 由导航器定义
-- END IF;
status := Show_LOV(lv_id,10,20);
END;
--- 定义一个'EXCEPTION' 例外
Declare
err_1 exception;
Begin
If ... then
Raise err-1;
End if;
Exception
When err_1 then
....
END;
--- 设置应用特性( 光标类型)
SET_APPLICATION_PROPERTY(CURSOR_STYLE,
'CROSSHAIR'|'BUSY'|'HELP'|'DEFAULT'|'INSERTION');
***********************************************************************
********************************** 函数*********************************
--- 把字符串的字符变成全大写(UPPER) 全小写(LOWER) 第一个字母大写(INITCAP)
UPPER|LOWER|INITCAP(STRING)
--- 在文件的左('LPAD') 右('RPAD') 粘贴字符
LPAD|RPAD(STRING,LENGTH,'SET') "LENGTH" 为总字符长"SET" 为粘贴字符
--- 在文件的左('LTRIM') 右('RTRIM') 删除字符
LTRIM|RTRIM(SRTING,'SET') "SET" 为待删除字符
--- 找出' 字符集' 在字符串中的位置
INSTR('STRING','SET',N,M) 从'STRING' 中找出'SET' 从'N' 位起第'M' 个
--- 数的绝对值
ABS(VALUE)
---'MOD' 模
MOD(VALUE, 除数) 返回' 除数' 除'VALUE' 的余数常用判断'VALUE' 是否为整数
--- 把'VALUE' 从'N' 位四舍五入'ROUND' 或从'N' 位截断'TRUNC'
ROUND|TRUNC(VALUE,N)
--- 返回'VALUE' 的符号
SIGN(VALUE)
--- 列表的最大值
GREATEST(N1,N1...);
列表的最小值
LEAST(N1,N1...);
--- 返回小于或等于数的最大整数
FLOOR(VALUE) floor(1.3)=1 floor(-1.3)=-2
--- 返回大于或等于数的最小整数
CEIL(VALUE) cell (1.3)=2 cell (-1.3)=-1
--- 取字符串长度
substr(string,start,number) number 为string 长度,start 为string 起点
---DECODE 函数, 多重(if,then,else)
decode(value,if1,then1,if2,then2,.....,else)
--- 判断'VALUE' 是否为空( 空值替换)
NVL(UALUE,'WKFHZ') 'WKFHZ' 是为空返回值, 不为空则为原值
--- 字段长度
length(:block_name.item_id)
--- 返回字符串的第一( 最左) 个字符的ascII 值
ascII(string)
--- 多行'VALUE' 的 ( 作用于多' 行')
AVG(VALUE) 平均值
COUNT(VALUE) 行数
MAX(VALUE) 最大值
MIN(VALUE) 最小值
SUM(VALUE) 和
--- 字符转换
TRANSLATE(STRING,' 待转字符',' 转换字符');
如 TEANSLATE('AAABBB','AB','BA') 返回'BBBAAA'
--- 比较单行中多个列的值获得最大('GREATEST' 最小('LEAST')
GREATEST|LEAST( 列名, 列名,...)
--- 按表达式或位置排序
ORDER BY ' 表达式'OR' 位置' ASC|DESC ASC' 升',DESC' 降' 默认'ASC'
***********************************************************************
***********************************************************************
--- 游标的属性
(1) %ISOPEN 打开属性
布尔型
打开为TRUE
判断' 光标' 是否打开如未打开则打开' 光标'
IF NOT(CORSOR_NAME%ISOPEN) THEN
OPEN CORSOR_NAME;
END IF;
FETCH CORSOR_NAME INTO ...
(2) %NOTFOUND 布尔型
最近一次'FETCH' 返回无结果
则为TRUE
OPEN CORSOR_NAME;
LOOP
FETCH CORSOR_NAME INTO ...
EXIT WHEN CORSOR_NAEM%NOTFOUND;
END LOOP;
(3) %FOUND 布尔型
最近一次'FETCH' 返回无结果
则为FALSE
OPEN CORSOR_NAME;
WHILE CORSOR_NAME%FOUND LOOP
......
FETCH CORSOR_NAME INTO ...
END LOOP;
CLOSE CORSOR_NAME;
(4) %ROWCOUNT NUMVER 型
为游标取出的行数
OPEN CORSOR_NAME;
LOOP
FETCH CORSOR_NAME INTO ...
EXIT WHEN CORSOR_NAME%ROWCOUNT>5;
......
END LOOP;
CLOSE CORSOR_NAME;
--- 循环语句
(1) 基本循环
LOOP
.....
EXIT WHILE; 如(EXIT WHEN X>100)
END LOOP;
(2)WHILE 循环
WHILE 如( WHEN X>100) LOOP
.....
END LOOP;
(3) 数值型FOR 循环 'X' 为计数器
FOR X IN ( 第减值) Y..Z LOOP
.....
END LOOP;
(4) 游标FOR 循环
---Exception( 例外) 在最近的'BEGIN' 和'END' 之间
Exception
语法1 当' 没有数据找到' 时
when no_data_found then
语法2 当' 发生任何错误' 时
when others then
语法3 当' 发现多行' 时
WHEN TOO_MANY_ROWS THEN
语法4 当' 字符向数字转换失败' 时
WHEN INVALID_NUMBER THEN
语法5 当' 被零除' 时
WHEN ZERO_DIVIDE THEN
语法6 当' 向唯一索引中插入重复数据' 时
WHEN DUP_VAL_ON_INDEX THEN
语法7 当' 非法游标操作' 时
WHEN INVALID_CURSOR THEN
语法8 当' 数字的, 数据转换, 截字符串或强制性的错误' 时
WHEN VALUE_ERROR THEN
**************************************************************************
**************************************************************************
-- 常用TEXT_IO
Delcare
out_file text_io.file_type;
Begin
out_file:=text_io.fopen('prn','w');
text_io.new_line(out_file,' ');
text_io.put_line(out_file,' ')
text_io.fclose(out_file);
End;
--- 文本输入输出
TEXT_IO
TEXT_IO PACKAGE
TEXT_IO FCLOSE
TEXT_IO.FILE_TYPE
TEXT_IO.FOPEN
TEXT_IO.IS_OPEN
TEXT_IO.GET_LINE
TEXT_IO.NEW_LINE
TEXT_IO.PUT
TEXT_IO.PUTF
TEXT_IO.PUT_LINE
USING TEXT_IO CONSTRUCTS
----------------------------
Declare
Out_file Text_io.file_type;
L Varchar2(100);
L1 Varchar2(100);
L2 Varchar2(100);
Begin
Out_file :=text_io.fopen('c:lllogin.txt','r');
If text_io.is_open(Out_file) then
text_io.get_line(Out_file,L);
text_io.get_line(Out_file,L1);
text_io.get_line(Out_file,L2);
Else
Null;
End if;
End;
--- 清除全局变量
erase('global.var_name');
--- 隐藏'WINDOW','VIEW','MENU'
HIDE_WINDOW|VIEW|MENU(WINDOW|VIEW|MENU_name);
--- 增加参数add_parameter
Declare
pl_id ParamList;
BEGIN
pl_id:=Get_Parameter_List('tempdata');
IF NOT Id_Null(pl_id) THEN
Destroy_Parameter_List(pl_id);
END IF;
pl_id:=Create_Parameter_List('tempdata');
Add_Parameter(pl_id,'EMP_QUERY',DATA_PARAMETER,'EMP_RECS');
Run_Product(REPORTS,'emp report',SYNCHRONOUS,RUNTIME,
FILESYSTEM,pl_id,NULL);
END;
---
DECLARE
lArgs OLE2.LIST_TYPE;
BEGIN
word.hApp:=OLE2.CREATE_OBJ('Word.Basic');
lArgs:=OLE2.CREATE_ARGLIST;
OLE2.ADD_ARG(lArgs, le.word_doc);
OLE2.INVOKE(Word.hApp,'fileopen',lArgs);
OLE2.DESTROY_ARGLIST(lArgs);
END;
*********************** 删除重复记录**************
Delete from emp e
where e.rowid >
(select min(f.rowid) from emp f
4 where f.empno=e.empno);