mysql 多语言_Oracle数据库多语言支持 红太狼 2022-11-05 03:06 139阅读 0赞 可以从Session, Instance, Database三个级别来对NLS参数进行设置。Session级别的设置覆盖Instance级别的设置,Instance级别的设置 一、NLS Parameter Oracle called globalization support National Language Support (NLS), 可以从Session, Instance, Database三个级别来对NLS参数进行设置。 Session级别的设置覆盖Instance级别的设置,Instance级别的设置覆盖Database级别的设置。 相应地,Oracle提供NLS\_SESSION\_PARAMETERS,NLS\_INSTANCE\_PARAMETERS,NLS\_DATABASE\_PARAMETERS这3个视图来查看NLS参数。 此外,还可以在SQL函数中指定NLS参数,这些函数称作locale-dependent。 A) NLS\_SESSION\_PARAMETERS此视图中的参数可以通过"ALTER SESSION "语句来进行设置。 ALTER SESSION SET parameter\_name=parameter\_value \[ parameter\_name=parameter\_value \]... ; 如果没有通过"ALTER SESSION "语句设置过,那么使用NLS\_LANG环境变量的定义值。(NLS\_LANG环境变量下面详细说明) 如果NLS\_LANG也没有被定义,那么沿用NLS\_INSTANCE\_PARAMETERS中的设定值。 这些参数影响到客户端的错误信息显示语言;日期,数字,货币等的显示格式;排序结果等。 B) NLS\_INSTANCE\_PARAMETERS此视图中中的参数设定是数据库启动时参照init.ora中的设定而来。 可以通过"ALTER SYSTEM"语句更改。 NLS\_LANGUAGE设定决定了alert.log和trace files中的Server错误信息的语言。 C) NLS\_DATABASE\_PARAMETERS 此视图中的参数是创建数据库时决定的。数据库创建好以后不能改动,不要通过修改系统表格来修改设定。 如果INSTANCE和SESSION参数没有设定,那么默认使用这里的参数。 NLS\_CHARACTERSET and NLS\_NCHAR\_CHARACTERSET 参数是创建数据库时决定的,不能被INSTANCE和SESSION参数覆盖,,不要在创建完数据库后试图修改它们,这种尝试会损坏数据库。(关于这2个参数下面有详细说明) 注1:NLS\_DATABASE\_PARAMETERS视图等价于SELECT name,value$ from sys.props$ where name like '%NLS%'。 注2:V$NLS\_PARAMETERS视图给出了当前的SESSION参数以及NLS\_DATABASE\_PARAMETERS视图中的2个CHARACTERSET参数。 注3:select userenv ('language') from dual; select sys\_context('userenv','language') from dual;这2个语句执行结果等同于 \_ ., 这个结果貌似NLS\_LANG,但是实际上不是,NLS\_LANG定义的是客户端的字符集。 注4:select userenv ('lang') from dual; 返回的是Session参数NLS\_LANGUAGE的简写。 注5:V$NLS\_VALID\_VALUES视图返回NLS\_LANGUAGE, NLS\_SORT, NLS\_TERRITORY, NLS\_CHARACTERSET的有效取值。 D) Locale-dependent SQL Function SQL functions whose behavior depends on the values of NLS parameters are called locale-dependent. 依赖于NLS参数的SQL函数包括: ?TO\_CHAR ?TO\_DATE ?TO\_NUMBER ?NLS\_UPPER ?NLS\_LOWER ?NLS\_INITCAP ?NLSSORT In all of the preceding functions, you can specify these NLS parameters:以上函数中可以指定的参数包括: ?NLS\_DATE\_FORMAT ?NLS\_DATE\_LANGUAGE ?NLS\_NUMERIC\_CHARACTERS ?NLS\_CURRENCY ?NLS\_ISO\_CURRENCY ?NLS\_DUAL\_CURRENCY ?NLS\_CALENDAR ?NLS\_SORT 此外对于NLSSORT函数,还可以指定以下参数。 ?NLS\_LANGUAGE ?NLS\_TERRITORY 按照'parameter=value' \['parameter=value'\]...的格式来指定参数。 例如, select to\_char(sysdate,'DD-MON-YYYY','NLS\_DATE\_LANGUAGE=''SIMPLIFIED CHINESE''') from dual;结果返回 "04-8月 -2011" select \* from employees order by nlssort(name,'NLS\_SORT=SCHINESE\_PINYIN\_M'); E) NLS\_LANG NLS\_LANG这个参数比较特殊,它是通过环境变量(UNIX)或者注册表(WINDOWS)定义的。它分三部分,格式如下: NLS\_LANG = \_.部分设定了SESSION的NLS\_LANGUAGE参数; \_部分设定了SESSION的NLS\_TERRITORY参数; .部分设定了CLIENT的字符集。它会影响到如何转换客户端的字符集到数据库字符集。 这三部分可以只定义任意一个/几个部分。 如果只有\_部分,默认等于AMERICAN; 如果只有部分,\_的值根据的值来决定; 如果既没有\_部分也没有部分,这2部分认等于AMERICAN\_AMERICA; 如果没有定义NLS\_LANG,那么默认值\_.US7ASCII,其中\_部分根据NLS\_INSTANCE\_PARAMETERS中的值来决定。 NLS\_LANG参数不能通过ALTER SESSION或者ALTER SYSTEM来更改(但是可以更改NLS\_LANGUAGE和NLS\_TERRITORY),也不能定义在init.ora中。 数据库创建的时候定义此参数也不影响数据库的设定,包括不会影响数据库的NLS\_CHARACTERSET and NLS\_NCHAR\_CHARACTERSET 参数。 NLS\_LANG参数的客户端字符集定义部分不能通过查询任何系统表格或视图得到。 (感觉实际上这个参数应该只会影响到客户端,也就是NLS\_SESSION\_PARAMETERS) NLS\_LANG直接设定了NLS\_LANGUAGE和NLS\_TERRITORY参数,还间接设定了其他的NLS参数。 NLS\_DATE\_LANGUAGE 和 NLS\_SORT 根据NLS\_LANGUAGE决定取值; NLS\_CURRENCY, NLS\_DUAL\_CURRENCY, NLS\_ISO\_CURRENCY, NLS\_DATE\_FORMAT, NLS\_TIMESTAMP\_FORMAT, NLS\_TIMESTAMP\_TZ\_FORMAT, NLS\_NUMERIC\_CHARACTERS 根据NLS\_TERRITORY决定取值。 注1:NLS\_LANG在WINDOWS注册表中的位置:HKEY\_LOCAL\_MACHINE\\SOFTWARE\\ORACLE\\KEY\_xxx NLS\_INSTANCE\_PARAMETERS shows the current NLS instance parameters that have been explicitly set and the values of the NLS instance parameters. These are the settings in the init.ora of the database at the moment that the database was started or set through ALTER SYSTEM. If the parameter is not explicitly set in the init.ora or defined by ALTER SYSTEM then its value is NOT derived from a "higher" parameter (we are talking about parameters like NLS\_SORT that derive a default from NLS\_LANGUAGE in NLS\_SESSION\_PARAMETERS, this is NOT the case for NLS\_INSTANCE\_PARAMETERS) \* NLS\_LANG is not an init.ora parameter; NLS\_LANGUAGE and NLS\_TERRITORY are so you need to set NLS\_LANGUAGE and NLS\_TERRITORY separately. \* You cannot define the or NLS\_LANG in the init.ora.The client characterset is defined by the NLS\_LANG on the client OS (see above). \* You cannot define the database characterset in the init.ora. The database characterset is defined by the "Create Database" command. \* These settings take precedence above the NLS\_DATABASE\_PARAMETERS. \* These values are used for the NLS\_SESSION\_PARAMETERS if the client the NLS\_LANG is NOT set. \* The NLS\_LANGUAGE in the instance parameters also declares the language for the server error messages in alert.log and in trace files. C) NLS\_DATABASE\_PARAMETERSNLS\_DATABASE\_PARAMETERS shows the values of the NLS parameters for the database. The values are stored in the database. Defaults to AMERICAN\_AMERICA if there are no parameters explicitly set in the init.ora during database creation time. If there is parameters set in the init.ora during database creation you see them here. There is no way to change these after the database creation. Do NOT attempt to update system tables to bypass these settings! These settings are used to give the database a default if the INSTANCE and SESSION parameters are not set. The database (national) character set NLS\_(NCHAR)\_CHARACTERSET) is defined by the "Create Database" command. \* The NLS\_CHARACTERSET and NLS\_NCHAR\_CHARACTERSET parameters cannot be overridden by instance or session parameters. They are defined by the value specified in the "CREATE DATABASE command and are not intended to be changed afterwards dynamically. Do NOT update system tables to change the character set. This can corrupt your database and potentially make it impossible to open the database again. \* Setting the NLS\_LANG during the creation of the database does not influence the NLS\_DATABASE\_PARAMETERS. \* The NLS\_LANG set during the database creation has NO impact on the database National Characterset. 本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:php中文网
相关 多语言支持:Java实现国际化应用及多语言资源管理 在Java中,实现国际化应用以及多语言资源管理主要涉及到以下几个方面: 1. **Resource Bundle**: Java提供了Resource Bundle A ╰半橙微兮°/ 2024年09月12日 06:45/ 0 赞/ 19 阅读
相关 如何处理前端多语言支持? 聚沙成塔·每天进步一点点 ⭐ 专栏简介 前端入门之旅:探索Web开发的奇妙世界 欢迎来到前端入门之旅!感兴趣的可以订阅本专栏哦!这个专栏是为那些对Web开发感 骑猪看日落/ 2024年02月21日 10:53/ 0 赞/ 13 阅读
相关 Qt / Qml 中支持多国语言 【缘起】 最近找到一个看起来比较好用的开源工具( 然鹅不太会用 ),但整个界面都是英文的。 不过由于是 Qt 写的,所以就尝试自己做些汉化。 然后了解到不少实现多国语 港控/mmm°/ 2023年02月11日 11:29/ 0 赞/ 18 阅读
相关 django支持多语言 Django支持多语言切换 下面介绍下如何使网站或APP国际化,让其支持多种语言 。 [官网][Link 1] 效果 ![在这里插入图片描述][20201006 ゝ一纸荒年。/ 2022年12月12日 04:53/ 0 赞/ 156 阅读
相关 mysql 多语言_Oracle数据库多语言支持 可以从Session, Instance, Database三个级别来对NLS参数进行设置。Session级别的设置覆盖Instance级别的设置,Instance级别的设置 红太狼/ 2022年11月05日 03:06/ 0 赞/ 140 阅读
相关 多语言支持如何显示各种语言的名称 Java的JDK已经包含了各种语言的显示名称,比如中文,在Locale.SIMPLIFIED\_CHINESE就显示为“中文 (中国)”,在Locale.E 末蓝、/ 2022年08月19日 00:29/ 0 赞/ 140 阅读
相关 Laravel 5.5 视图 - 多语言支持 简介 Laravel 的本地化特性允许你在应用中轻松实现多语言支持。语言字符串默认存放在 resources/lang 目录中,该目录包含了应用支持的每种语言的子目录。 Myth丶恋晨/ 2022年05月15日 03:23/ 0 赞/ 180 阅读
相关 Android 多语言支持 添加多国语言文件 下面以添加 西班牙语 为例,首先在 res 右键 “new”,选择 “Values resource file”。 ![在这里插入图片描述][2019 浅浅的花香味﹌/ 2022年03月15日 04:08/ 0 赞/ 553 阅读
相关 DevExpress VCL的多语言支持文件 用法1:在工程中加入控件cxLocalizer; 在程序中加入如下语句: Localizer.LoadFromFile(语言文件.ini); Localizer.L 怼烎@/ 2021年11月23日 19:34/ 0 赞/ 240 阅读
还没有评论,来说两句吧...