这个涉及到oracle字符集的问题若此时数据库服务器已启动,则先执行SHUTDOWN IMMEDIATE命令关闭数据库服务器,然后执行以下命令:
  SQL>STARTUP MOUNT;
  SQL>ALTER SYSTEM ENABLE RESTRICTED SESSION;
  SQL>ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
  SQL>ALTER SYSTEM SET AQ_TM_PROCESSES=0;
  SQL>ALTER DATABASE OPEN;
  SQL>ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK; //跳过超子集检测
  SQL>ALTER DATABASE national CHARACTER SET INTERNAL ZHS16GBK;
这一行不起作用,执行后出错ORA-00933: SQL 命令未正确结束,不过执行上一行命令已经生效,不用担心,继续下面操作。
  SQL>SHUTDOWN IMMEDIATE;
  SQL>STARTUP
执行完后检测是否成功:
sql>select  userenv('langvage') from dual,
如果出现以下图片所示情况就ok了

解决方案 »

  1.   

    select userenv('language') from dual;
    查看服务器的字符集,
    然后再注册表里面修改本地字符集,一样的话基本没问题。
      

  2.   

    这个涉及到oracle字符集的问题若此时数据库服务器已启动,则先执行SHUTDOWN IMMEDIATE命令关闭数据库服务器,然后执行以下命令:
      SQL>STARTUP MOUNT;
      SQL>ALTER SYSTEM ENABLE RESTRICTED SESSION;
      SQL>ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
      SQL>ALTER SYSTEM SET AQ_TM_PROCESSES=0;
      SQL>ALTER DATABASE OPEN;
      SQL>ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK; //跳过超子集检测
      SQL>ALTER DATABASE national CHARACTER SET INTERNAL ZHS16GBK;
    这一行不起作用,执行后出错ORA-00933: SQL 命令未正确结束,不过执行上一行命令已经生效,不用担心,继续下面操作。
      SQL>SHUTDOWN IMMEDIATE;
      SQL>STARTUP
    执行完后检测是否成功:
    sql>select  userenv('langvage') from dual,
      

  3.   

    服务区器读取的是服务器的字符集,
    而cmd 读的其实才是客户端也就是client的字符集。
    plsql读取的是自己的字符集(在注册表中),所以你应该修改注册表中的字符集。