设为首页 收藏本站
查看: 590|回复: 0

[经验分享] oracle笔记三(系统函数和系统包使用方面)

[复制链接]
YunVN网友  发表于 2016-8-15 06:20:46 |阅读模式
  1.十进制和十六进制转换
  (oracle 8i以后)
  select to_char(125,'XXXXX') from dual
  -----------
  7D
  select to_char(125,'xxxxx') from dual
  -----------
  7d
  select to_number('7D','XXXXX') from dual
  -----------
  125
  2. ORACLE产生随机函数
  DBMS_RANDOM.RANDOM
  3、调度程序 DBMS_JOB
  
   broken 中止一个任务调度
   change 修改任务的属性
   internal 改变间隔
   submit 任务发送到任务队列中去
   next_date 改变任务的运行时间
   remove 删除一个任务
   run 立即执行一个任务
   submit 提交一个任务
   user_export 任务说明
   what 改变任务运行的程序
  查询
   select * from user_job;
   建立一存储过程
   create or replace procedure log_proc as
   begin
   insert into test(aa) values(sysdate);
   commit;
   end;
   提交一个任务
   declare
   job_num number;
   begin
   dbms_job.submit(job_num,'log_proc;',sysdate,sysdate+5/(24*60*60),false);
   dbms_output.put_line('Job numer='||to_char(job_num));
   end;
   1> 上面程序从当前开始,间隔5秒执行一次。
   2> 如果每天几点执行,可以写为(比如从2004-09-13开始执行,每天7点执行)
   next_date => to_date('13-09-2004 07:00:00', 'dd-mm-yyyy hh24:mi:ss'),
   interval => 'trunc(sysdate)+(7+24)/24')
   3> 如果是每个月几号开始执行。比如每月2号21点执行。
   add_months(trunc(sysdate,'MONTH'),1) + 2-1 + 21/24
  
   移走任务
   begin
   dbms_job.remove(1);
   end;
   中止任务
   begin
   dbms_job.broken(1,true);
   end;
   查询正在执行的job
   select * from dba_jobs_running
   如果运行比较慢,加
   select /*+ rule */* from dba_jobs_running
  4.UTL_FILE包
  在PL/SQL 3.3以上的版本中,UTL_FILE包允许用户通过PL/SQL读写操作系统文件。如下:
  DECALRE
  FILE_HANDLE UTL_FILE.FILE_TYPE;
  BEGIN
  FILE_HANDLE:=UTL_FILE.FOPEN('C:\','TEST.TXT','A');
  UTL_FILE.PUT_LINE(FILE_HANDLE,'HELLO,IT iS A TEST TXT FILE');
  UTL_FILE.FCLOSE(FILE_HANDLE);
  END;
  比如:怎么样在Oracle中写操作系统文件,如写日志
  可以利用utl_file包,但是,在此之前,要注意设置好Utl_file_dir初始化参数
  /**************************************************************************
  parameter:textContext in varchar2 日志内容
  desc: ·写日志,把内容记到服务器指定目录下
  ·必须配置Utl_file_dir初始化参数,并保证日志路径与Utl_file_dir路径一致或者是其中一个
  ****************************************************************************/
  CREATE OR REPLACE PROCEDURE sp_Write_log(text_context VARCHAR2)
  IS
  file_handle utl_file.file_type;
  Write_content VARCHAR2(1024);
  Write_file_name VARCHAR2(50);
  BEGIN
  --open file
  write_file_name := 'db_alert.log';
  file_handle := utl_file.fopen('/u01/logs',write_file_name,'a');
  write_content := to_char(SYSDATE,'yyyy-mm-dd hh24:mi:ss')||'||'||text_context;
  --write file
  IF utl_file.is_open(file_handle) THEN
  utl_file.put_line(file_handle,write_content);
  END IF;
  --close file
  utl_file.fclose(file_handle);
  EXCEPTION
  WHEN OTHERS THEN
  BEGIN
  IF utl_file.is_open(file_handle) THEN
  utl_file.fclose(file_handle);
  END IF;
  EXCEPTION
  WHEN OTHERS THEN
  NULL;
  END;
  END sp_Write_log;
  5.SYS_CONTEXT的详细用法
  select
  SYS_CONTEXT('USERENV','TERMINAL') terminal,
  SYS_CONTEXT('USERENV','LANGUAGE') language,
  SYS_CONTEXT('USERENV','SESSIONID') sessionid,
  SYS_CONTEXT('USERENV','INSTANCE') instance,
  SYS_CONTEXT('USERENV','ENTRYID') entryid,
  SYS_CONTEXT('USERENV','ISDBA') isdba,
  SYS_CONTEXT('USERENV','NLS_TERRITORY') nls_territory,
  SYS_CONTEXT('USERENV','NLS_CURRENCY') nls_currency,
  SYS_CONTEXT('USERENV','NLS_CALENDAR') nls_calendar,
  SYS_CONTEXT('USERENV','NLS_DATE_formAT') nls_date_format,
  SYS_CONTEXT('USERENV','NLS_DATE_LANGUAGE') nls_date_language,
  SYS_CONTEXT('USERENV','NLS_SORT') nls_sort,
  SYS_CONTEXT('USERENV','CURRENT_USER') current_user,
  SYS_CONTEXT('USERENV','CURRENT_USERID') current_userid,
  SYS_CONTEXT('USERENV','SESSION_USER') session_user,
  SYS_CONTEXT('USERENV','SESSION_USERID') session_userid,
  SYS_CONTEXT('USERENV','PROXY_USER') proxy_user,
  SYS_CONTEXT('USERENV','PROXY_USERID') proxy_userid,
  SYS_CONTEXT('USERENV','DB_DOMAIN') db_domain,
  SYS_CONTEXT('USERENV','DB_NAME') db_name,
  SYS_CONTEXT('USERENV','HOST') host,
  SYS_CONTEXT('USERENV','OS_USER') os_user,
  SYS_CONTEXT('USERENV','EXTERNAL_NAME') external_name,
  SYS_CONTEXT('USERENV','IP_ADDRESS') ip_address,
  SYS_CONTEXT('USERENV','NETWORK_PROTOCOL') network_protocol,
  SYS_CONTEXT('USERENV','BG_JOB_ID') bg_job_id,
  SYS_CONTEXT('USERENV','FG_JOB_ID') fg_job_id,
  SYS_CONTEXT('USERENV','AUTHENTICATION_TYPE') authentication_type,
  SYS_CONTEXT('USERENV','AUTHENTICATION_DATA') authentication_data
  from dual
  6.怎么样在过程中暂停指定时间
  DBMS_LOCK包的sleep过程
  如:dbms_lock.sleep(5);表示暂停5秒。
  7.怎么在Oracle中发邮件
  可以利用utl_smtp包发邮件,以下是一个发送简单邮件的例子程序
  /****************************************************************************
  parameter: Rcpter in varchar2 接收者邮箱
  Mail_Content in Varchar2 邮件内容
  desc: ·发送邮件到指定邮箱
  ·只能指定一个邮箱,如果需要发送到多个邮箱,需要另外的辅助程序
  ****************************************************************************/
  CREATE OR REPLACE PROCEDURE sp_send_mail( rcpter IN VARCHAR2,
  mail_content IN VARCHAR2)
  IS
  conn utl_smtp.connection;
  --write title
  PROCEDURE send_header(NAME IN VARCHAR2, HEADER IN VARCHAR2) AS
  BEGIN
  utl_smtp.write_data(conn, NAME||': '|| HEADER||utl_tcp.CRLF);
  END;
  BEGIN
  --opne connect
  conn := utl_smtp.open_connection('smtp.com');
  utl_smtp.helo(conn, 'oracle');
  utl_smtp.mail(conn, 'oracle info');
  utl_smtp.rcpt(conn, Rcpter);
  utl_smtp.open_data(conn);
  --write title
  send_header('From', 'Oracle Database');
  send_header('To', '"Recipient" ');
  send_header('Subject', 'DB Info');
  --write mail content
  utl_smtp.write_data(conn, utl_tcp.crlf || mail_content);
  --close connect
  utl_smtp.close_data(conn);
  utl_smtp.quit(conn);
  EXCEPTION
  WHEN utl_smtp.transient_error OR utl_smtp.permanent_error THEN
  BEGIN
   utl_smtp.quit(conn);
  EXCEPTION
   WHEN OTHERS THEN
   NULL;
  END;
  WHEN OTHERS THEN
  NULL;
  END sp_send_mail;
  8.怎么样获取对象的DDL语句
  第三方工具就不说了主要说一下9i以上版本的dbms_metadata
  <1>获得单个对象的DDL语句
  set heading off
  set echo off
  set feedback off
  set pages off
  set long 90000
  select dbms_metadata.get_ddl('TABLE','TABLE_NAME','SCAME') from dual;
  比如
  select dbms_metadata.get_ddl('TABLE','CM_USER','AICBS') from dual;
  <2>.如果获取整个用户的脚本,可以用如下语句
  select dbms_metadata.get_ddl('TABLE',u.table_name) from user_tables u;
  当然,如果是索引,则需要修改相关table到index
  <3>.还有
  dbms_metadata.get_xml()

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-257695-1-1.html 上篇帖子: Oracle数据库备份与恢复的三种方法 下篇帖子: Oracle数据库中如何改善表空间的管理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表