您好,登錄后才能下訂單哦!
這篇文章主要講解了“GBase8s數(shù)據(jù)庫有什么特點”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“GBase8s數(shù)據(jù)庫有什么特點”吧!
將數(shù)據(jù)導入到GBase8s數(shù)據(jù)庫中,我們會進行建庫、建表、建字段的操作,當這些操作完成以后在初期導入一些測試或樣例數(shù)據(jù)的時候都比較順利。但有時到了正式環(huán)境,數(shù)據(jù)變多以后,里面藏著一些意向不到的特殊字符或生僻字會導致我們導入失敗。所以以此文檔記錄在GBase8s建庫過程中對生僻字處理的注意事項
n DB_LOCALE
含義:
通過 DB_LOCALE 環(huán)境變量設置的數(shù)據(jù)庫語言環(huán)境指定數(shù)據(jù)庫服務器用于正確解釋特定數(shù)據(jù)庫中語言環(huán)境相關的數(shù)據(jù)類型(NCHAR 和 NVARCHAR)所需的語言、地域和代碼集。DB_LOCALE 中指定的代碼集確定哪些字符在任何字符列中都是有效的,并且確定數(shù)據(jù)庫對象(如數(shù)據(jù)庫、表、列和視圖)的名稱。數(shù)據(jù)庫服務器使用 DB_LOCALE 環(huán)境變量指定的數(shù)據(jù)庫代碼集將數(shù)據(jù)傳入和傳出數(shù)據(jù)庫。
用途:
1. 在客戶機應用程序和數(shù)據(jù)庫服務器交換字符數(shù)據(jù)時,如果 DB_LOCALE 環(huán)境變量(在客戶機計算機上)的值與 CLIENT_LOCALE 的值不同,客戶機應用程序將執(zhí)行代碼集轉換。 代碼集轉換防止這兩種代碼集不同時發(fā)生數(shù)據(jù)破壞。
2. 在客戶機應用程序請求連接時,它將包括 DB_LOCALE(如果已設置)的信息發(fā)送至數(shù)據(jù)庫服務器。
3. 在確定如何設置服務器處理語言環(huán)境的數(shù)據(jù)庫信息時,數(shù)據(jù)庫服務器使用 DB_LOCALE。
4. 在客戶機應用程序嘗試打開數(shù)據(jù)庫時,數(shù)據(jù)庫服務器將客戶機應用程序傳遞的 DB_LOCALE 環(huán)境變量的值與數(shù)據(jù)庫中存儲的數(shù)據(jù)庫語言環(huán)境進行比較。
5. 當數(shù)據(jù)庫服務器存取與語言環(huán)境相關的數(shù)據(jù)類型的列時,數(shù)據(jù)庫服務器使用 DB_LOCALE 指定的語言環(huán)境。
6. 當數(shù)據(jù)庫服務器創(chuàng)建新數(shù)據(jù)庫時,它將檢查數(shù)據(jù)庫語言環(huán)境(DB_LOCALE),以確定如何在數(shù)據(jù)庫的系統(tǒng)目錄中存儲字符信息。此信息包括諸如如何處理正則表達式、比較字符串以及確保代碼集的正確使用的操作。
所以如果我們的數(shù)據(jù)庫需要支持中文字符,我們必須在建庫的時候必須將該變量設置為zh_CN.utf8或zh_cn.GB18030-2000。否則如果按照en_us.8859-1進行建庫后,在插入中午字符后將會變成亂碼。以下是字符集名稱及編碼對照表
字符集名稱 | 編碼 |
8859-1 | 819 |
gb | 57357 |
GB2312-80 | 57357 |
utf8 | 57372 |
big5 | 57352 |
GB18030-2000 | 5488 |
字符集名稱及編碼對照表
n GL_USEGLU
含義:
如果想使NCHAR 和 NVARCHAR數(shù)據(jù)類型的字段內(nèi)的數(shù)據(jù)支持unicode,則必須對GL_USEGLU環(huán)境變量進行使用設置
所以如果我們的數(shù)據(jù)庫不僅需要支持中文,還需要支持生僻字符,則必須在建庫前開啟此變量
我們需要把生僻字“”插入到數(shù)據(jù)庫中,根據(jù)剛才的描述我們需要正確設置兩個地方才能保證“”字成功入庫
我們首先使用echo $DB_LOCALE;命令查看當前該變量的值
發(fā)現(xiàn)當前該變量的值不是zh_CN.utf8或zh_cn.GB18030-2000
所以我們在建立數(shù)據(jù)庫之前,需要先將變量進行修改
其次我們需要使用onstat -g env命令確認GL_USEGLU是否進行了設置
當這兩個變量都設置完畢后,我們使用dbaccess建立數(shù)據(jù)庫testdb3
建表操作、新增生僻字記錄,詳情如下圖所示,操作成功
使用如下語句確認當前數(shù)據(jù)庫的編碼,顯示的是zh_CN.57372, 根據(jù)剛才的字符集名稱及編碼對照表,可知編碼57372對應的字符集名稱是utf8
SELECT * FROM sysmaster:sysdbslocale WHERE dbs_dbsname like 'testdb3%';
以下是我們測試當不設置GL_USEGLU變量的情況
我們通過unset GL_USEGLU命令變量使GL_USEGLU失效
使用onstat -g env命令對當前環(huán)境變量進行查看,發(fā)現(xiàn)已經(jīng)沒有了 GL_USEGLU環(huán)境變量
此時我們通過dbaccess建立了testdb4數(shù)據(jù)庫
我們再插入剛才的生僻字“”將會如下圖所示報錯 34389 Illegal character 非法字符
再來測試插入正常漢字的情況
插入正常漢字是沒有問題的
感謝各位的閱讀,以上就是“GBase8s數(shù)據(jù)庫有什么特點”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對GBase8s數(shù)據(jù)庫有什么特點這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。