⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 oracle开发技巧-9.htm

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

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -