linux oracle utf8编码设置,Oracle数据库之设置 Oracle,Sqlplus,Linux 设置为UTF8 专治中文乱码 ,查看表的创建过程...

本文主要向大家介绍了Oracle数据库之设置 Oracle,Sqlplus,Linux 设置为UTF8 专治中文乱码 ,查看表的创建过程,通过具体的内容向大家展现,希望对大家学习Oracle数据库有所帮助。

思想:1,设置Linux字符集 为UTF8编码2,设置Oracle字符集 为UTF8编码3,设置sqlplus客户端环境 为UTF8编码4,如果是在Windows使用CRT/Xshell远程工具,请设置软件编码为UTF8[略...]1,先设置oracle为UTF8[oracle@oracle11 ~]$ sqlplus /nolog

SQL> conn /as sysdba;

SQL> 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 utf8;

SQL> shutdown immediate;

SQL> startup;

SQL> conn scott/11

SQL> set linesize 299;

SQL> set pagesize 299;

SQL> select * from v$nls_parameters where PARAMETER=‘NLS_CHARACTERSET‘;

PARAMETER  VALUE

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

NLS_CHARACTERSET UTF8

SQL> select userenv(‘language‘) from dual;

AMERICAN_AMERICA.UTF8

SQL> exit2,Linux系统一般默认都是UTF8,以CentOS为例:[oracle@oracle11 ~]$ cat /etc/sysconfig/i18n

LANG="en_US.UTF-8"

SYSFONT="latarcyrheb-sun16"3,设置sqlpuls环境变量,测试NLS_LANG的值来自下面这条语句:SQL> select userenv(‘language‘) from dual; AMERICAN_AMERICA.UTF8[oracle@oracle11 ~]$ cd /home/oracle/

[oracle@oracle11 ~]$ echo "export NLS_LANG=\"AMERICAN_AMERICA.UTF8\"" >> .bashrc

[oracle@oracle11 ~]$ . .bashrc

[oracle@oracle11 ~]$ echo $NLS_LANG

AMERICAN_AMERICA.UTF8

[oracle@oracle11 ~]$ sqlplus scott/11

SQL> set linesize 299;

SQL> set pagesize 299;

SQL> create table student (sid number(2) primary key, sname varchar2(50) not null,address varchar2(50), sex varchar2(1),age number(2));

SQL> insert into student values(1,‘宋江‘,‘梁山好汉‘,‘m‘,20);

SQL> select * from student;

SID SNAME     ADDRESS   S   AGE

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

1 宋江      梁山好汉     m         20

到scott原始表测试一下:

SQL> insert into dept(deptno,dname,loc) values(23,‘中‘,‘国‘);

SQL> select * from dept;

23 中             国

10 ACCOUNTING   NEW YORK

20 RESEARCH   DALLAS

30 SALES   CHICAGO

40 OPERATIONS   BOSTON

6 rows selected.查看表的创建过程:使用DBMS_METADATA.GET_DDL(‘TABLE‘,‘TABLE_NAME‘)函数SQL> set pagesize 0;

SQL> set long 1000;

SQL> select DBMS_METADATA.GET_DDL(‘TABLE‘,‘STUDENT‘) from dual;

CREATE TABLE "SCOTT"."STUDENT"

( "SID" NUMBER(2,0),

"SNAME" VARCHAR2(50) NOT NULL ENABLE,

"ADDRESS" VARCHAR2(50),

"SEX" VARCHAR2(1),

"AGE" NUMBER(2,0),

PRIMARY KEY ("SID")

USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255

STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645

PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER

_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE D

EFAULT)

TABLESPACE "USERS"  ENABLE

) SEGMENT CREATION IMMEDIATE

PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS L

OGGING

STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645

PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE

DEFAULT CELL_FLASH_CACHE DEFAULT)

TABLESPACE "USERS"

SQL>

本文由职坐标整理并发布,希望对同学们学习Oracle有所帮助,更多内容请关注职坐标数据库Oracle数据库频道!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值