11 SQL*Plus Globalization Support
Globalization support enables the storing, processing and retrieval of data in native languages. The languages that can be stored in an Oracle database are encoded by Oracle Database-supported character sets. Globalization support ensures that database utilities, error messages, sort order, and date, time, monetary, numeric, and calendar conventions adjust to the native language and locale.
Topics:
For more information on globalization support, see the Oracle Technology Network globalization notes at http://www.oracle.com/technetwork/products/globalization/
and see Overview of Globalization Support.
11.1 About Configuring Globalization Support in Command-line SQL*Plus
SQL*Plus supports multiple languages through the NLS_LANG environment variable. To display another language in SQL*Plus, before starting SQL*Plus you must configure:
-
NLS_LANG in the SQL*Plus client environment.
-
The Oracle Database during installation.
11.1.1 SQL*Plus Client
The SQL*Plus client environment is configured by setting the NLS_LANG environment variable which is read by SQL*Plus at startup.
11.2 NLS_LANG Environment Variable
The NLS_LANG environment variable has three components, each controlling a subset of the globalization features.
Your operating system and keyboard must be able to support the character set you have chosen. You may need to install additional support software. For more information about NLS_LANG, and software support, see Setting Up a Globalization Support Environment.
Setting up locale specific behavior on the SQL*Plus client is achieved with the use of NLS parameters. These parameters may be specified in a number of ways, including as an initialization parameter on the server. For settings that control the behavior of the server, see NLS Database Parameters.
NLS_LANG has the syntax:
NLS_LANG = language_territory.charset
where language specifies the conventions to use for Oracle Database messages, sorting order, day and month names. For example, to receive messages in Japanese, set language to JAPANESE. If language is not set, it defaults to AMERICAN.
where territory specifies the convention for default dates, and for monetary, and numeric formats. For example to use the Japanese territory format, set territory to JAPAN. If territory is not set, the default value is derived from the language value, and so is set to AMERICA.
where, in SQL*Plus command-line, charset specifies the character set encoding used by SQL*Plus for data processing, and is generally suited to that of the users terminal. Illogical combinations can be set, but will not work. For example, Japanese cannot be supported using a Western European character set such as:
NLS_LANG=JAPANESE_JAPAN.WE8DEC
However, Japanese could be supported with the Unicode character set. For example:
NLS_LANG=JAPANESE_JAPAN.UTF8
11.2.1 Viewing NLS_LANG Settings
You can view the NLS_LANG setting by entering the SELECT command:
SELECT * FROM NLS_SESSION_PARAMETERS;
The NLS_TERRITORY and NLS_LANGUAGE values correspond to the language and territory components of the NLS_LANG variable.
You can also obtain a list of valid values for the NLS_SORT, NLS_LANGUAGE, NLS_TERRITORY and NLS_CHARACTERSET by querying the NLS dynamic performance view table V$NLS_VALID_VALUES.
11.3 Setting NLS_LANG
You can set the NLS_LANG environment variable to control globalization features.
Example 11-1 Configuring Japanese Support in SQL*Plus on Windows
-
Ensure you have exited your current SQL*Plus session.
-
Open System from Start > Settings > Control Panel.
-
Click the Advanced tab and select Environment Variables.
-
Create a new environment variable, NLS_LANG, with a value of Japanese_Japan.JA16SJIS.
-
You may need to restart Windows for this setting to take effect.
Example 11-2 Configuring Japanese Support in SQL*Plus on UNIX
-
Ensure you have exited your current SQL*Plus session.
-
Set the NLS_LANG variable using either set or setenv depending on the UNIX shell you are using. For example, in csh, you would enter:
setenv NLS_LANG Japanese_Japan.UTF8
or
setenv NLS_LANG Japanese_Japan.JA16SJIS
or
setenv NLS_LANG Japanese_Japan.JA16EUC
The locale setting of your UNIX terminal determines the exact value of the NLS_LANG parameter. For more information on the NLS_LANG setting, see Specifying the Value of NLS_LANG.
Example 11-3 Configuring Japanese Support in Oracle Database
To store data in the Japanese character set using UTF-8 character encoding, ensure that the Oracle database has been created with the AL32UTF8 character set. See your Oracle Database Installation Guide for information about creating your database in a character set other than US7ASCII.