これはaix 6100-02上のOracle 10gr2です。
問題はOracleからの€記号が表示されない
これは問題を確認する簡単な方法です。
SQL> insert into prueba values ('€');
SQL> commit;
SQL> select * from prueba;
EURO
------------------------------------------------------------
¿
SQL>
これは私がすでに行ったテストです
私はそれをシェルから見る:
Oracle@krats:/u01#Perl -Mcharnames=:full -CS -wle 'print "\N{EURO SIGN}"'
€
Oracle@krats:/u01#
しかし、私はそれをsqlから見ません:
SQL> select chr(128) from dual;
C
-
SQL>
このデータベースには、次のNLS_SESSION_PARAMETERSがあります。
SQL> SELECT * FROM NLS_SESSION_PARAMETERS;
PARAMETER VALUE
------------------------------ ----------------------------------------
NLS_LANGUAGE SPANISH
NLS_TERRITORY SPAIN
NLS_CURRENCY ¿
NLS_ISO_CURRENCY SPAIN
NLS_NUMERIC_CHARACTERS ,.
NLS_CALENDAR GREGORIAN
NLS_DATE_FORMAT DD/MM/RR
NLS_DATE_LANGUAGE SPANISH
NLS_SORT SPANISH
NLS_TIME_FORMAT HH24:MI:SSXFF
NLS_TIMESTAMP_FORMAT DD/MM/RR HH24:MI:SSXFF
PARAMETER VALUE
------------------------------ ----------------------------------------
NLS_TIME_TZ_FORMAT HH24:MI:SSXFF TZR
NLS_TIMESTAMP_TZ_FORMAT DD/MM/RR HH24:MI:SSXFF TZR
NLS_DUAL_CURRENCY ¿
NLS_COMP BINARY
NLS_LENGTH_SEMANTICS BYTE
NLS_NCHAR_CONV_EXCP FALSE
17 filas seleccionadas.
SQL>
これを表示するためだけにテーブルを作成しました。
Oracle@krats:/u01#NLS_LANG=SPANISH_SPAIN.UTF8
Oracle@krats:/u01#export NLS_LANG
Oracle@krats:/u01#sqlplus "/ as sysdba"
SQL> create table prueba (euro nvarchar2(20));
table created.
SQL> insert into prueba values ('€');
1 fila creada.
SQL> commit;
Confirmación terminada.
SQL> select * from prueba;
EURO
------------------------------------------------------------
¿
SQL>
最後に、重要かどうかはわかりませんが、これはOracleユーザーの環境変数です。
SQL> Host env;
_=/usr/bin/env
LANG=en_US
LOGIN=Oracle
PAGER=/usr/bin/pg
PATH=/usr/bin:/etc:/usr/sbin:/usr/ucb:/u01/bin:/usr/bin/X11:/sbin:.:/u01/Oracle/product/10.2/db_1/bin/
NLS_LANG=SPANISH_SPAIN.WE8ISO8859P1
Oracle_BASE=/u01/Oracle/product
LC__FASTMSG=true
EDITOR=/usr/bin/vim
KM_CRYPTO_LIB_PATH=/usr/lib/libkmcryptolib.so
LOGNAME=Oracle
MAIL=/usr/spool/mail/Oracle
LOCPATH=/usr/lib/nls/loc
Oracle_SID=DIESEL
PS1=Oracle@krats:${PWD}#
USER=Oracle
AUTHSTATE=files
ORA_NLS10=/u01/Oracle/product/10.2/db_1/nls/data
Shell=/usr/bin/ksh
ODMDIR=/etc/objrepos
R_SHLIB_LD_LIBRARY_PATH=/usr/lib
HOME=/u01
FCEDIT=/usr/bin/vi
TERM=vt100
MAILMSG=[YOU HAVE NEW MAIL]
Oracle_HOME=/u01/Oracle/product/10.2/db_1
PWD=/u01
TZ=Europe/Madrid
KM_SUPPORT_LIB_PATH=/usr/lib/libkmsvcshlib.so
Oracle_BIN=/u01/Oracle/product/10.2/db_1/bin/
A__z=! LOGNAME
NLSPATH=/usr/lib/nls/msg/%L/%N:/usr/lib/nls/msg/%L/%N.cat
SQL>
誰かが同様の状況に直面しましたか?
どうもありがとう。
データベースの文字セットはWE8ISO8859P1
ですが、€
記号がありません。 NVARCHAR2
を使用するか、データベースの文字セットを変更します(エクスポート、WE8ISO8859P15
やAL32UTF8
などのユーロ記号をサポートする文字セットで再インストールし、インポートします)。
NVARCHAR2
の例を次に示します。
SQL> SELECT * FROM nls_database_parameters WHERE parameter LIKE '%SET';
PARAMETER VALUE
------------------------------ ----------------------------------------
NLS_NCHAR_CHARACTERSET AL16UTF16
NLS_CHARACTERSET WE8ISO8859P1
ご覧のとおり、私はあなたと同じ状況です。
SQL> CREATE TABLE prueba (id NUMBER, euro NVARCHAR2(20));
Table created.
SQL> INSERT INTO prueba VALUES (1, N'€');
1 row created.
SQL> INSERT INTO prueba VALUES (2, UNISTR('\20AC'));
1 row created.
SQL> INSERT INTO prueba VALUES (3, NCHR(8364));
1 row created.
SQL> INSERT INTO prueba VALUES (4, CHR(8364 USING NCHAR_CS));
1 row created.
SQL> INSERT INTO prueba VALUES (5, '€');
1 row created.
SQL> SELECT id, euro, ascii(euro) FROM prueba;
ID EURO ASCII(EURO)
---------- -------------------- -----------
1 € 8364
2 € 8364
3 € 8364
4 € 8364
5 ¿ 191