• Oracle乱码的问题


    1.sql脚本直接能执行但是以sql文件不能执行

    sql正常,由txt转换为sql文件后,数据库执行报错,解决办法是将sql文件中数据取出放到新文件中,新文件保存时直接以sql格式保存。

    2.乱码问题

    1.如果导入到plsql中显示乱码,首先查看sql的存储格式,修改成utf-8

    2.查看服务器端编码—

    select userenv('language') from dual;

    我实际查到的结果为: SIMPLIFIED CHINESE_CHINA.ZHS16GBK

    (AMERICAN_AMERICA.AL32UTF8)这个也是常用的  AMERICAN_AMERICA.ZHS16GBK

     

    如果不正确的话设置方法:----在oracle的数据上去执行的

    [oracle@ORACLE ~]$ sqlplus /nolog

    conn /as sysdba;

    select userenv('language') from dual;

    SHUTDOWN IMMEDIATE

    STARTUP MOUNT

    ALTER SYSTEM ENABLE RESTRICTED SESSION;

    ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;

    ALTER SYSTEM SET AQ_TM_PROCESSES=0;

    ALTER DATABASE OPEN;

    ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK;

    SHUTDOWN IMMEDIATE;

    STARTUP;

    查看一下是否修改过来

    select userenv('language') from dual;

    3.客户端

    执行语句 select * from V$NLS_PARAMETERS  

    查看第一行中PARAMETER项中为NLS_LANGUAGE 对应的VALUE项中是否和第一步得到的值一样。

    或者途中的NLS_LANGUAGE和NLS_CHARACTERSET中的value的值加到一起和服务器中额编码是否一致。

    如果不是,需要设置环境变量.或者修改注册表 regedit

    NLS_LANG

    否则PLSQL客户端使用的编码和服务器端编码不一致,插入中文时就会出现乱码.

    2.Unix/Linux环境,查看和修改NLS_LANG变量的方法
    1)查看方法,在oracle用户下使用env命令获得系统的环境变量列表,然后使用grep命令定位到“NLS_LANG”内容
    $ env | grep NLS_LANG
    NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

    2)修改方法:使用export命令设置该环境变量
    $ NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
    $ export NLS_LANG

    很全的知识

    https://www.2cto.com/database/201111/111388.html

  • 相关阅读:
    中国剩余定理
    【BZOJ】【3053】The Closest M Points
    【BZOJ】【1878】【SDOI2009】HH的项链
    【BZOJ】【2648】SJY摆棋子&【BZOJ】【2716】【Violet 3】天使玩偶
    【UOJ Easy Round #2】
    【TYVJ 五月图论专项有奖比赛】
    【BZOJ】【3301】【USACO2011 Feb】Cow Line
    【BestCoder】【Round#41】
    【BZOJ】【1046】/【POJ】【3613】【USACO 2007 Nov】Cow Relays 奶牛接力跑
    【BZOJ】【3210】花神的浇花集会
  • 原文地址:https://www.cnblogs.com/fengxiaoyuan/p/9982119.html
Copyright © 2020-2023  润新知