ORALCE substr函數及substrb與字元集關係

来源:https://www.cnblogs.com/rogerfederer/archive/2023/07/21/17571571.html
-Advertisement-
Play Games

ORALCE substr函數及substrb與字元集關係 語法 函數用途: SUBSTR函數用來截取從源字元(參數 char)中截取一部分目標字元,截取方式為限定從源字元截取起始位置(參數 positon),並限定截取目標字元長度(參數 substring_length)。substr系列函數計算 ...


ORALCE substr函數及substrb與字元集關係

 

語法

   函數用途: SUBSTR函數用來截取從源字元(參數 char)中截取一部分目標字元,截取方式為限定從源字元截取起始位置(參數 positon),並限定截取目標字元長度(參數 substring_length)。substr系列函數計算目標字元長度及開始截取字元位置長度的方式有所不同——substr函數為字元,substrb為位元組,substrc為UNICODE完全字元集,substr2為UCS2編碼代碼點,substr4為ucs4編碼代碼點。

 

 

  • 參數position為0時,按1處理。
  • 參數position為正數時,ORACLE數所庫查詢時從左到右從第一個字元開始計數。
  • 參數position 為負數時,查詢從右向左從倒數第一個字元開始計數。
  • 參數substring_length可為空,為空時直接從position位置開始向後截取所有字元(含position位置字元)。哪果substring為負值 ,則substr函數返還null。

   char參數類型可以是 char,varchar2,nchar,nvarchar2,clob或者nclob,但除substr與substrb函數外,另外三個substr系列函數的參數char類型不允許 為CLOB(character large object) 或者NCLOB類型。position與substringlength參數數據類型必須是number數值型,或者可以被隱式轉換為number型的數據類型,並且最終最必須可以被轉換為整型。返回值的類型一般與char參數的數據類型一致,但char、nchar類型的參數返回值實際上分別為varchar2 、nvarchar2類型.position與substringlength參數如果為浮點型數據則被直接自動處理為整型數據。

   示例:
   1.

   SELECT SUBSTR('ABCDEFG',3,4) "Substring" FROM DUAL;
  

   以上語句返回'CDEF',即從第三個字元'C'開始,向右截取長度為4的目標字元,為'CDEF'.

 


   2.

   SELECT SUBSTR('ABCDEFG',-5,4) "Substring" FROM DUAL;
  

   以上語句返回'CDEF',即從倒數第五個字元'C'開始,向右截取長度為4的目標字元,為'CDEF'.此處position參數為負值值是起始位置計算從右向左,但截取方向依然為從左向右,而instr(string,substring,position,occurence)函數position參數為負值 時,不僅取起始位置是從右向左,並且匹配計算目標字元串出現次數方向也是從右向左。

 


3.

SELECT SUBSTRB('ABCDEFG',5,4.2) "Substring with bytes" FROM DUAL;  

   substrb函數與substr函數不同之處在於它以位元組來計數,而substr函數僅單純以字元來計算,不論是中文還是英文。因此,由於資料庫系統字元集編碼方式的不一致,不同資料庫系統執行上述語句結果可能有所不同。例3示例語句在GBK字元集下,字母占1位元組,因此返還值為'EFG',即從第5個位元組'E'開始,向右截取4個位元組(不滿4個截到末尾即可);而如果是UNICODE字元集,中英文均占2位元組,因此返還值為'CD'.下麵是一些常見的編碼格式字元所占位元組情況:

 

  • 1、ASII:美國標準信息交換碼,用一個位元組的7位可以表示。無漢字字元,一個字母對應一個位元組。;
  • 2、ISO8859-1:拉丁碼表,歐洲碼表,用一個位元組的8位可以表示;
  • 3、GBK2312:中國的中文編碼表,最多兩個位元組編碼所有字元。一個漢字2位元組,一個字母1位元組;
  • 4、GBK:中國的中文編碼表升級,融合了更多的中文文字字元,最多兩個位元組編碼。一個漢字2位元組,一個字母1位元組;
  • 5、Unicode:國際標準碼,融合了目前人類使用的所有字元,為每個字元分配唯一的字元碼,所有的文字都用兩個位元組來表示;
  • 6、utf-8:變長的編碼方式,可用1-4個位元組來表示一個字元。現在最多的又有6個位元組。一個漢字3位元組,一個字母1位元組; -7、utf-16:中文和字母都是占2個位元組。 -8、utf-32:中文和字母都是占4個位元組。

ORACLE字元串存儲方式

   ORACLE資料庫中varchar2類型字元串有varchar2(n char) 和varchar2(n byte)兩種存放方式。一般直接定義為varchar2(n),這樣ORALCE會根據配置文件中的設置選擇以位元組還是以字元為單位。查看具體是以哪種方式可能在PLSQL命令行輸入以下命令查看value值:

show parameter nls_length

 

ORACLE字元集

   可能通過以下語句查詢當前登錄資料庫字元集:

elect userenv('language') from dual;


   ORACLE的字元存儲方式與字元集共同決定了一個varchar2型欄位能存儲什麼長度什麼形式的字元,比如:一個varchar2(4)長度的欄位,如果 採用的是GBK編碼方式,即一個漢字占2位元組,字母占1位元組,且存儲方式為byte,則此欄位最多存儲2漢字,4字母。

 

參考文檔 ORALCE官網 SQL Language Reference:https://docs.oracle.com/en/database/oracle/oracle-database/21/sqlrf/About-SQL-Functions.html#GUID-D51AB228-518C-4213-8BD4-F919623D105E


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • asp.net項目開發過程中用到了多個程式集(dll), 如何根據類型全名(fullname)獲取類型信息? 如果項目(csproj)中設置了引用對應的dll 或nupkg包,但是代碼中沒有任務地方引用改該程式集的類,則實際上運行時,該程式集不會被載入到進程中. 假設有一個 ThirdModels. ...
  • # Unity UGUI的CanvasScaler(畫布縮放器)組件的介紹及使用 ## 1. 什麼是CanvasScaler組件? CanvasScaler是Unity中UGUI系統中的一個組件,用於控制畫布的縮放和適配。通過CanvasScaler組件,可以實現UI界面在不同解析度下的自適應顯示。 ...
  • ### 描述 asp.net Core Identity提供給我們一組工具包和API,能幫助我們應用程式創建授權和認證功能。也可以用它創建賬戶並使用用戶名和密碼進行登錄,同時也提供了角色和角色管理功能。 #### 1.創建項目 - 配置項 - nuget包 - Microsoft.AspNetCor ...
  • # shell腳本-DOS攻擊防範(自動屏蔽攻擊IP) ## 原理: #### **找出異常ip** > 通過獲取伺服器access.log日誌信息,獲取時間在每分鐘之內每個ip訪問的次數來判斷此ip是否是DOS攻擊。 > > grep $(date +%d/%b/%Y:%H:%M) 過濾得到沒分鐘 ...
  • **註:** Silverlight工作流控制項,如果在網頁中打不開,則要判斷是否缺少`Silverlight工作流控制項`的插件程式,如果不是則可以進行一下步驟檢查,如果是以下原因則是:由於IIS版本問題,安裝後可能出現不支持wcf服務的請求處理,需要手動添加處理程式;資料庫客戶端如果是64位,需要修 ...
  • 今天給大家分享一下STM32 流水燈簡單的模擬吧,我感覺這個提供有用的,但是自己也是第一次使用,主要是感覺曲線很高級。在PWM中查看脈寬很有用。 code: led.c #include "led.h"#include "delay.h"/*GPIO的控制寄存器的配置1、配置輸出引腳2、打開對應的輸 ...
  • # clion申請教育認證 ## 1、註冊jetbrains賬號 [jetbrains註冊賬號網站鏈接](https://account.jetbrains.com/login) ![picture 1](https://img2023.cnblogs.com/blog/2915785/202307 ...
  • 一、多表關係 一對多或者多對一 案例:部門與員工的關係 關係:一個部門對應多個員工,一個員工對應一個部門(不考慮跨部門的特殊情況) 實現:在多的一方建立外鍵,指向一的一方的主鍵,這裡員工表是多的的一方,部門表是一的一方 多對多 案例:學生與課程的關係 關係:一個學生可以選修多門課程,一門課程也可以供 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...