web-dev-qa-db-ja.com

€ユーロ記号/記号がOracle 10gr2およびaix 6.1に表示されない

これは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>

誰かが同様の状況に直面しましたか?

どうもありがとう。

2
Marc Riera

データベースの文字セットはWE8ISO8859P1ですが、記号がありません。 NVARCHAR2 を使用するか、データベースの文字セットを変更します(エクスポート、WE8ISO8859P15AL32UTF8などのユーロ記号をサポートする文字セットで再インストールし、インポートします)。

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
5
Vincent Malgrat