當前位置:首頁 » 編程語言 » sql規范數字字元串
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

sql規范數字字元串

發布時間: 2023-03-09 03:44:00

A. Oracle中如何用sql把字元串轉換成整型

您可以使用cast函數將數字字元串轉化為整型。

cast函數格式如下:

CAST(欄位名 as int);

拓展資料

結構化查詢語言(Structured Query Language)簡稱SQL(發音:/ˈes kjuː ˈel/ "S-Q-L"),是一種特殊目的的編程語言,是一種資料庫查詢和程序設計語言,用於存取數據以及查詢、更新和管理關系資料庫系統;同時也是資料庫腳本文件的擴展名。

結構化查詢語言是高級的非過程化編程語言,允許用戶在高層數據結構上工作。它不要求用戶指定對數據的存放方法,也不需要用戶了解具體的數據存放方式,所以具有完全不同底層結構的不同資料庫系統, 可以使用相同的結構化查詢語言作為數據輸入與管理的介面。結構化查詢語言語句可以嵌套,這使它具有極大的靈活性和強大的功能。

1986年10月,美國國家標准協會對SQL進行規范後,以此作為關系式資料庫管理系統的標准語言(ANSI X3. 135-1986),1987年得到國際標准組織的支持下成為國際標准。不過各種通行的資料庫系統在其實踐過程中都對SQL規范作了某些編改和擴充。所以,實際上不同資料庫系統之間的SQL不能完全相互通用。

B. 第三章 SQL語言元素(一)

InterSystems SQL命令(也稱為SQL語句)以關鍵字開頭,後跟一個或多個參數。其中一些參數可能是子句或函數,由它們自己的關鍵字標識。

InterSystems SQL關鍵字包括命令名稱,函數名稱,謂詞條件名稱,數據類型名稱,欄位約束,優化選項和特殊變數。它們還包括 AND , OR 和 NOT 邏輯運算符, NULL 列值指示符以及ODBC函數構造,例如 {d dateval} 和 {fn CONCAT(str1,str2)} 。

聚合函數是SQL固有函數,它計算列的所有值並返回單個聚合值。

這種寫法只能在mac routine里,類文件里編譯報錯。

如果將用戶提供的(外部)函數的使用配置為系統范圍的選項,則該SQL語句只能調用用戶提供的(外部)函數。默認為「否」。默認情況下,嘗試調用用戶提供的函數會發出 SQLCODE -372 錯誤。可以使用 %SYSTEM.SQL類的SetAllowExtrinsicFunctions() 方法在系統范圍內配置SQL對外部函數的使用。若要確定當前設置,請調用 $SYSTEM.SQL.CurrentSettings() ,該顯示顯示「允許在SQL語句中使用外部函數」選項。

不能使用用戶提供的函數來調用 %routine (名稱以%字元開頭的常式)。
嘗試這樣做會發出 SQLCODE -373 錯誤。

InterSystems SQL文字具有以下語法:

文字是一系列代表實際(文字)值的字元。它可以是數字或字元串。

空字元串是文字字元串;它由兩個單引號字元( '' )表示。 NULL 不是文字值;它表示沒有任何值。

注意:在嵌入式SQL中,不允許在字元串文字中使用以 ## 開頭的一些字元序列,如「使用嵌入式SQL」一章的「文字值」中所述。此限制不適用於其他SQL調用,例如動態SQL。

使用單引號( ' )字元作為字元串定界符。 SQL兼容性支持雙引號字元( 「 )的使用,但由於與定界標識符標准沖突,因此強烈建議不要使用。將一對雙引號字元 "" 解析為無效的定界標識符。並生成 SQLCODE -1 錯誤。

要在字元串中指定單引號字元作為字面字元,請指定一對這樣的字元作為字面轉義序列。
例如, 'a 'normal' string' 。

雙豎條( || )是首選的SQL連接操作符。
它可以用於連接兩個數字、兩個字元串或一個數字和一個字元串。

下劃線( _ )作為SQL連接操作符提供,以保證ObjectScript的兼容性。
此連接操作符只能用於連接兩個字元串。

如果兩個操作數都是字元串,並且兩個字元串都具有相同的排序規則類型,則所得的級聯字元串具有該排序規則類型。在所有其他情況下,連接的結果是排序類型 EXACT 。

使用 NULL 關鍵字表示沒有指定值。
在SQL中, NULL 始終是表示數據值因任何原因未指定或不存在的首選方式。

SQL零長度字元串(空字元串)由兩個單引號字元指定。
空字元串( " )與空字元串是不同的。
空字元串是一個已定義的值,一個不包含字元的字元串,一個長度為0的字元串。
一個零長度的字元串在內部由非顯示字元 $CHAR(0) 表示。

注意:不建議使用SQL零長度字元串作為欄位輸入值或欄位默認值。
使用 NULL 表示數據值的缺失。

在SQL編碼中應避免使用SQL零長度字元串。
但是,由於許多SQL操作都會刪除末尾的空格,所以只包含空格字元(空格和製表符)的數據值可能會導致SQL的零長度字元串。

注意,不同的SQL length函數返回不同的值: length 、 CHAR_LENGTH 和 DATALENGTH 返回SQL長度。
$LENGTH 返回ObjectScript表示長度。
長度不計算尾隨空格;
所有其他長度函數都計算末尾的空格。

NOT NULL數據約束要求欄位必須接收一個數據值;
不允許指定NULL而不是值。
這個約束不阻止使用空字元串值。

SELECT 語句的 WHERE 或 HAVING 子句中的 IS NULL 謂詞選擇空值;
它不選擇空字元串值。

IFNULL 函數計算一個欄位值,如果欄位值為 NULL ,則返回第二個參數中指定的值。
它不會將空字元串值視為非空值。

COALESCE 函數從提供的數據中選擇第一個非空值。
它將空字元串值視為非空值。

當 CONCAT 函數或 concenate 操作符( || )連接一個字元串和一個 NULL 時,結果是 NULL 。
如下面的例子所示:

AVG、COUNT、MAX、MIN 和 SUM 聚合函數在執行操作時忽略 NULL 值。
( COUNT * 統計所有行,因為不可能有一個所有欄位都為空值的記錄。)
SELECT 語句的 DISTINCT 關鍵字在其操作中包含 NULL ;
如果指定的欄位有空值, DISTINCT 返回一個空行.

AVG 、 COUNT 和 MIN 、聚合函數受空字元串值的影響。
MIN 函數將空字元串視為最小值,即使存在值為0的行。
MAX 和 SUM 聚合函數不受空字元串值的影響。

對大多數SQL函數提供 NULL 作為操作數將返回 NULL 。

任何以NULL作為操作數的SQL算術操作都返回 NULL 值。
因此,7 +零=零。
這包括二元運算加法( + )、減法( - )、乘法( * )、除法( / )、整數除法( )和取模( # ),以及一元符號運算符加號( + )和減號( - )。

算術操作中指定的空字元串將被視為0(零)值。
除法( / ),整數除法( ),或對空字元串( 6/ " )取模( # )會導致 <DIVIDE> 錯誤。

在SQL中, NULL 的長度是沒有定義的(它返回 < NULL > )。
然而,空字元串的長度被定義為長度為0。
如下面的例子所示:

如本例所示,SQL LENGTH 函數返回SQL長度。

可以使用 ASCII 函數將SQL的零長度字元串轉換為 NULL ,示例如下:

但是,對標准 SQL 的某些系統間IRIS擴展對 NULL 和空字元串的長度的處理是不同的。
$LENGTH函數返回這些值的InterSystems IRIS內部表示: NULL 表示為長度為0的已定義值,SQL空字元串表示為長度為0的字元串。
該功能與ObjectScript兼容。

這些值的內部表示方式的另一個重要位置是 %STRING 、 %SQLSTRING 和 %SQLUPPER 函數,它們將空格附加到值中。
因為 NULL 實際上沒有值,所以在它後面添加一個空格會創建一個長度為1的字元串。
但是一個空字元串確實有一個字元值,所以在它後面加上一個空格會創建一個長度為2的字元串。
如下面的例子所示:

注意,這個例子使用的是 CHAR_LENGTH ,而不是 LENGTH 。
因為 LENGTH 函數刪除了末尾的空格,所以 LENGTH(%STRING(NULL)) 返回長度為0的字元串;
LENGTH(%STRING(")) 返回長度為2的字元串, 因為 %STRING 追加的是前導空格,而不是尾隨空格。

當SQL NULL 輸出到ObjectScript時,它由ObjectScript空字元串( "" )表示,長度為0的字元串。

當SQL零長度字元串數據輸出到ObjectScript時,它由包含 $CHAR(0) 的字元串表示,該字元串長度為1。

在ObjectScript中,沒有值通常用空字元串( "" )表示。
當這個值被傳遞到嵌入式SQL中時,它會被視為空值,如下面的例子所示:

如果指定了一個未定義的輸入主機變數,嵌入式SQL將其值視為 NULL 。

當將NULL或空字元串值從嵌入式SQL傳遞到ObjectScript時, NULL 被轉換為長度為0的字元串,空字元串被轉換為長度為1的字元串。
如下面的例子所示:

在下面的例子中,SQL的空字元串加上一個空格被傳遞為長度為2的字元串:

C. sql語句中怎樣將字元類型轉換成數字類型

先檢查金額列的數據是否都符合小數規范,轉為數字格式只有是數字的字元串才能轉,如000012轉為12,.55轉為0.55,若是個英文符號等字元轉了就報無效數字類型的錯。

D. 第二十八章 SQL函數 CHAR_LENGTH

返回表達式中的字元數的函數。

CHAR_LENGTH 返回整數數據類型。

CHAR_LENGTH 返回一個整數值,表示指定表達式中的字元數,而不是位元組數。表達式可以是字元串,也可以是任何其他數據類型,如數字或數據流欄位。返回的整數計數包括前導和尾隨空格以及字元串終止字元。如果傳遞 NULL 值,則 CHARACTER_LENGTH 返回 NULL ,如果傳遞空字元串( 『』 )值,則返回0。

在計算字元之前,會將數字解析為規范形式;不會解析帶引號的數字字元串。在下面的示例中,第一個 CHAR_LENGTH 返回 1 (因為數字分析刪除了前導和尾隨零),第二個 CHAR_LENGTH 返回 8 。

注意: CHAR_LENGTH 、 CHARACTER_LENGTH 和 DATALENGTH 函數是相同的。
它們都接受一個流欄位參數。
LENGTH 和 $LENGTH 函數不接受流欄位參數。

LENGTH 與這些函數的不同之處在於,在計算字元之前會去掉尾隨空格和字元串終止字元。

$LENGTH 也不同於這些函數,因為如果傳入一個 NULL 值,它返回0,如果傳入一個空字元串,則返回0。
$LENGTH 與其他長度函數的不同之處是返回數據類型 SMALLINT ;
所有其他長度函數返回的數據類型為 INTEGER 。

下面的示例返回 Sample.Employee 中狀態縮寫欄位( Home_State )中的字元數。

(美國各州都有兩個字母的郵政縮寫):

下面的例子返回員工的名字和每個員工名字中的字元數,按字元數升序排列:

以下示例返回 Sample.Employee 表中的字元流欄位( Notes )和二進制流欄位( Picture )中的字元數:

下面的嵌入式SQL示例顯示 CHAR_LENGTH 如何處理 Unicode 字元。 CHAR_LENGTH 計算字元數,而不考慮其位元組長度:

E. SQL 查詢一列中,數字字元串中,最後一個數字欄位的簡單語句

結論:作為補充,我們使用MySQL字元串操作函數進行篩選。

like

只要是字元串操作函數,可達到篩選目的的一般均可使用。

但是查詢性能需視情況而定。


以上。

F. 用PL/SQL如何查詢出純數字字元串

SELECT * FROM a WHERE columnA LIKE '%\%%' ESCAPE'\';
其中,ESCAPE'\'表示:\為換碼字元,匹配串中跟在\後面的字元%不再具有通配符的含義;
轉義為普通的「%」字元。