日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

oracle中的nls在哪,Oracle的NLS设置

發布時間:2025/3/15 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle中的nls在哪,Oracle的NLS设置 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

NLS lsquo;National Language Support (NLS)rsquo; 從概念我們看出這個參數實際上定義了數據庫的存放數據的語言環境,當

一:介紹一個概念:

NLS  ‘National Language Support (NLS)’ 從概念我們看出這個參數實際上定義了數據庫的存放數據的語言環境,當我們設定一種nls的時候實際上我們是為Oracle在存放數據時指定了他的語種所特 有的一些表達形式,比如我們選擇chinese,那么它的中文字符如何存放,按什么規則排序,貨幣如何表示,日期格式也就被設定了。

二:如何查詢我們的數據庫中到底使用的是什么字符集

SQL> select * from V$NLS_PARAMETERS;

NLS_LANGUAGE                     SIMPLIFIED CHINESE

NLS_TERRITORY                          CHINA

NLS_CURRENCY                           RMB

NLS_ISO_CURRENCY                         CHINA

NLS_NUMERIC_CHARACTERS                      .,

NLS_CALENDAR                         GREGORIAN

NLS_DATE_FORMAT                       DD-MON-RR

NLS_DATE_LANGUAGE                  SIMPLIFIED CHINESE

NLS_CHARACTERSET                       ZHS16GBK

NLS_SORT                             BINARY

NLS_TIME_FORMAT                      HH.MI.SSXFF AM

NLS_TIMESTAMP_FORMAT             DD-MON-RR HH.MI.SSXFF AM

NLS_TIME_TZ_FORMAT                  HH.MI.SSXFF AMTZR

NLS_TIMESTAMP_TZ_FORMAT         DD-MON-RR HH.MI.SSXFF AM TZR

NLS_DUAL_CURRENCY                        RMB

NLS_NCHAR_CHARACTERSET                  AL16UTF16

NLS_COMP                             BINARY

NLS_LENGTH_SEMANTICS                       BYTE

NLS_NCHAR_CONV_EXCP                       FALSE

其中nls_language表示了中文顯示方式,nls_characterset是字符集設定,另外date,time等為日期時間的格式,currency是貨幣格式。

三:存在問題及解決方法

我們在使用字符集過程中主要存在兩種問題。

一是我們在查詢時顯示中文部分顯示亂字符。

這一般是由于服務器端的字符集設定與客戶端的字符集設定不同造成的。只要將兩者修改一致就可以解決問題。

在windows里需要到注冊表里local machine-software-oracle-home0里更改nls_lang,,unix下需要在.profile或這.bash_profile(根據你用的shell)里更改nls_lang.

二是我們在導入數據時提示字符集不匹配問題。(有些可以兼容的不用管)

解決方法目前我看到3種

1:)exp/imp與sql*plus一樣是客戶端產品,因此他的字符集是由服務端的nls_lang所設定的。用exp導出備份的export file時,字符集的設定也被存放在export file里。這就是有些人在imp發生字符無法轉換時更改export file文件頭的原理。

2:) <=8.1

在imp之前執行SQL > create database character set US7ASCII

* create database character set US7ASCII

ERROR at line 1:

ORA-01031: insufficient privileges

---- 你會發現語句執行過程中,出現上述錯誤提示信息,此時不用理會,實際上ORACLE數據庫的字符集已被強行修改為US7ASCII,接著用imp命令裝載 數據。等數據裝載完成以后,shutdown 數據庫,再startup 數據庫,用合法用戶登錄ORACLE數據庫,在sql>命令提示符下,運行select * from V$NLS_PARAMETERS,可以看到ORACLE數據庫字符集已復原,這時再查看有漢字字符數據的表時,漢字已能被正確顯示。

3:)用數據管道導入數據

這種方法我早期用過pb6的數據管道,將數據管道連接至需要導入導出的兩個數據庫進行數據傳輸,傳輸后中文顯示沒有問題。

4:)更該數據字典props$  >8.1

1. )Use SQL*Plus connect to database as user SYS

2. )Issue this below command

SQL> UPDATE PROPS$ SET VALUE$='xxx' WHERE;

3.) Shutdown database and restart it

最后添加一個關于字符集可以自動轉換方面的(在imp時):

Warning You can't change character set of current database that have number of bits greater than the new one. For example,

我理解就是7-8 can,8-8ican,8-8cannot,8-7cannot

US7ASCII -> WE8ISO8859P1 => Can

TH8TISASCII -> US7ASCII => Cannot

WE8ISO8859P1 -> TH8TISASCII => Cannot

TH8TISASCII -> WE8ISO8859P1 => Can

US7ASCII -> TH8TISASCII => Can

總結

以上是生活随笔為你收集整理的oracle中的nls在哪,Oracle的NLS设置的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。