zoukankan      html  css  js  c++  java
  • 修改sqlplus中显示时间日期的格式

     

    在数据库里查询数据的时候,我们经常会遇到一些和日期时间格式的问题,比如显示语言,显示格式等。可能数据在数据库里面存放的格式是:YYYY-MM-DD HH24:MI:SS, 但我们查询出来的却是 22-1-10, 第一反应可能是字符集出了问题。 其实还有一个原因就是系统环境变量没有设置,下面我们就来看下有关这个的配置问题。

     

    1.  session 中修改

     

    1. 1 中英文的切换

    SQL> alter session set NLS_DATE_LANGUAGE='SIMPLIFIED CHINESE';

     

    会话已更改。

     

    SQL> select sysdate from dual;

     

    SYSDATE

    --------------

    22-1 -10

     

    SQL> alter session set NLS_DATE_LANGUAGE='AMERICAN';

     

    会话已更改。

     

    SQL> select sysdate from dual;

     

    SYSDATE

    ------------

    22-JAN-10

     

    SQL>

     

    1.2 时间格式的切换

     

    SQL> alter session set NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS';

     

    会话已更改。

     

    SQL> select sysdate from dual;

     

    SYSDATE

    -------------------

    2010-01-22 14:30:21

     

    SQL>



    2.
    在操作系统中设置相关环境变量



    2.1 windows 平台


    C:> SET NLS_DATE_FORMAT=YYYY-MM-DD HH24:MI:SS

    C:> SET NLS_DATE_LANGUAGE=AMERICAN

    C:>SEET NLS_DATE_LANGUAGE=SIMPLIFIED CHINESE;

     

    注意:这里YYYY-MM-DD HH24:MI:SS不能加引号,但在unix系统中要加

    SQL> select sysdate from dual;
    SYSDATE

    -------------------

    2010-01-22 14:33:21



     这样改了以后只对当前的控制台窗品有效,如果不想每次都设置,就修改系统/用户环境变量,新增一个变量,比如nls_date_format,值为YYYY-MM-DD HH24:MI:SS 就可以了。

     

    2.2 Linux 平台

    $export  NLS_DATE_FORMAT=”YYYY-MM-DD HH24:MI:SS”

    $export  NLS_DATE_LANGUAGE=”AMERICAN”

    $export  NLS_DATE_LANGUAGE=”SIMPLIFIED CHINESE”

     

    注:在unix系统中要加引号

     

    Export 只对当前session 有效,如果要长期保存,就需要修改.bash_profile 参数,比如Oracle用户的,/home/oracle/.bash_profile, 在该文件中加入相关参数以后就可以了。

     

    NLS_DATE_FORMAT=”YYYY-MM-DD HH24:MI:SS”; 

    export NLS_DATE_FORMAT;

    NLS_DATE_LANGUAGE=”AMERICAN”; 

          export NLS_DATE_LANGUAGE;

    NLS_DATE_LANGUAGE=”SIMPLIFIED CHINESE”;

      export NLS_DATE_LANGUAGE;

     

    补充:

    修改时间日期的格式并不单是显示上的问题,而是在内部存储的值也会被覆盖:

    SQL> select to_date(to_char(sysdate,'yyyy-mm-dd')) from dual;
    select to_date(to_char(sysdate,'yyyy-mm-dd')) from dual
                   *
    ERROR at line 1:
    ORA-01861: literal does not match format string

    在没有修改环境变量或session参数时,这个语句是无法执行的。修改后可以执行:

    SQL> select to_date(to_char(sysdate,'yyyy-mm-dd')) from dual;

    TO_DATE(TO
    ----------
    2010-1-22

    注:把参数NLS_DATE_FORMAT设置成yyyy-mm-dd,查询的过滤条件中date类型的字段就可以跟日期控件生成的时间字符串直接比较了,非常方便的,如果对查询速度要求高,可以给日期类型的字段创建一个基于函数的索引。

     

     

    道森Oracle,国内最早、最大的网络语音培训机构,我们提供专业、优质的Oracle技术培训和服务! 我们的官方网站:http://www.daosenoracle.com 官方淘宝店:http://daosenpx.taobao.com/
  • 相关阅读:
    [BJOI2006]狼抓兔子
    hdu 1878 欧拉回路,图的连通性判断
    poj 3844 Divisible Subsequences 剩余类,组合计数
    LA 4609 ,poj 3842 An Industrial Spy
    hdu 4639 2013多校第四场 hehe Fibonacci 数列,组合计数,字符串处理
    hdu 4642 Fliping game 翻硬币游戏 抓住特征变量
    13多校#4 ,组队赛#18 总结
    ACM 大牛的博客
    LA 4329 Ping Pong 2008 北京区域赛 H , BIT 二叉索引树(树状数组)的应用
    poj 2689 Prime Distance 二次筛法,找出给定区间所有约数
  • 原文地址:https://www.cnblogs.com/tianlesoftware/p/3610283.html
Copyright © 2011-2022 走看看