网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.关于dbms_stats取代analyze.
.Linux 系统的优化和微调.
.PLSQL单行函数和组函数详解.
.使数据库为归档模式.
.Connect To Oracle DataBase.
.应对RMAN-06026错误,使用dbms_b.
.DearBook + Itpub 北京区Oracle.
.Oracle SQL的优化(2).
.ORACLE性能诊断―学习statspack笔.
.将EXP出来的数据IMP进不同的表空.
.在Oracle数据库XE上构建Google E.
.巧取指定的记录与巧用外关联查询.
.创建一个ORACLEstandby database.
.数据库考试简介——Oracle认证.
.新手浅谈数据库中的设计技巧(一).
.关于shared pool的深入探讨(一).
.Linux中的两个问题及目录组织.
.一条有用的sql文(ORACLE).
.利用ORACLE系统账户默认口令提升.
.Oracle数据库的ORA-00257故障解决.

从Unix到Oracle的日期转换

发表日期:2008-2-9



  CREATE OR REPLACE FUNCTION Unix_To_Oracle_Date
  (
    p_unix_date IN NUMBER, -- Range of >= 0
    p_num_hr_gmt_diff IN PLS_INTEGER  -- Range of -24 to +24
  
  ) RETURN DATE AS
  
  /*
    Function Name:  Unix_To_Oracle_Date
  
    Purpose:     To calculate an Oracle date based on a Unix GMT date
             in seconds, since the epoch of Unix (January 1st, 1970).
  
             The date returned will be based on the number of hours
             the oracle database system clock is either ahead or behind
             the Greenwich Mean Time line.
  
             If the parameters do not fall within the specified ranges
             then the returned date will be NULL.
  
    Developer Name:  Giovanni Jaramillo
    Developer Email: Giovanni@CheckOut.com
    Creation Date:  Copyright ? CheckOut.com December 2, 1999
  
    Parameters:    p_unix_date of NUMBER type (Range is > 0 only)
             p_num_hr_gmt_diff of PLS_INTEGER type (Range -24 to +24)
  
    Input:      NONE
    Output:      NONE
    Returned value:  DATE := Unix_To_Oracle_Date(p_Unix_Date);
  
  */
  
    -- CONSTANTS
  
    -- These 2 CONSTANTS below are of POSITIVE type to indicate that they
    -- CANNOT be less than 1
  
    c_SECONDS_IN_DAY CONSTANT POSITIVE := 86400;
    c_HOURS_IN_DAY CONSTANT POSITIVE := 24;
  
  
    c_UNIX_EPOCH_DATE_TIME_STRING CONSTANT VARCHAR2(50) := '01/01/1970 00:00:00';
    c_DATE_FORMAT CONSTANT VARCHAR2(50) := 'MM/DD/YYYY HH24:MI:SS';
  
    -- VARIABLES
  
    v_sql_code PLS_INTEGER;
    v_sql_error_message VARCHAR2(512);
  
    -- The 2 variables have to be of NUMBER type because a PLS_INTEGER divided by
    -- another PLS_INTEGER can result in a fraction, thus the result must be of
    -- NUMBER type only
  
    v_unix_seconds NUMBER;
    v_gmt_time_gap NUMBER;
  
    v_return_value DATE;
  
  BEGIN
  
    IF(NOT (p_num_hr_gmt_diff < (-c_HOURS_IN_DAY)) AND
     NOT (p_num_hr_gmt_diff > (c_HOURS_IN_DAY))) THEN
  
     v_unix_seconds := (p_unix_date / c_SECONDS_IN_DAY);
     v_gmt_time_gap := (p_num_hr_gmt_diff / c_HOURS_IN_DAY);
  
     v_return_value := TO_DATE(c_UNIX_EPOCH_DATE_TIME_STRING, c_DATE_FORMAT) +
              v_unix_seconds + v_gmt_time_gap;
    ELSE
     v_return_value := NULL;
    END IF;
  
    RETURN(v_return_value);
  
  EXCEPTION
  
    WHEN OTHERS THEN
     v_sql_code := SQLCODE;
     v_sql_error_message := SQLERRM(v_sql_code);

  
     DBMS_OUTPUT.PUT_LINE('OTHER ERROR');
     DBMS_OUTPUT.PUT_LINE(v_sql_error_message);
  
  END Unix_To_Oracle_Date;
上一篇:手工创建数据库的全部脚本及说明 人气:591
下一篇:如何查看Oracle数据表的建表语句 人气:719
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐