1. 程式人生 > >DB2 字符串拼接 在字段前加0操作 0||‘字段名稱’

DB2 字符串拼接 在字段前加0操作 0||‘字段名稱’

mssq oracle數據庫 字符串拼接 com mss -m ref 方式 sql

摘自 http://blog.csdn.net/milife2013/article/details/8660205

DB2字符串連接和oracle數據庫相同,使用“||”進行DB2字符串連接,其使用方式和MSSQLServer中的加號“+”一樣。比如執行下面的SQL語句:
SELECT ‘工號為‘||FNumber||‘的員工姓名為‘||FName FROM T_Employee
WHERE FName IS NOT NULL

除了“||”,DB2還支持使用CONCAT()函數進行字符串拼接,比如執行下面的SQL語句:
SELECT CONCAT(‘工號:‘,FNumber) FROM T_Employee

與Oracle不同,如果CONCAT中連接的值不是字符串,則DB2不會嘗試進行類型轉換而是報出錯誤信息,比如執行下面的SQL語句是錯誤的:
SELECT CONCAT(‘年齡:‘,FAge) FROM T_Employee

運行以後DB2會報出下面的錯誤信息:
未找到類型為"FUNCTION" 命名為 "CONCAT" 且具有兼容自變量的已授權例

與MYSQL的CONCAT()函數不同,DB2的CONCAT()函數只支持兩個參數,不支持兩個以上字符串的拼接,比如下面的SQL語句在Oracle中是錯誤的:
SELECT CONCAT(‘工號為‘,FNumber,‘的員工姓名為‘,FName) FROM T_Employee
WHERE FName IS NOT NULL
運行以後Oracle會報出下面的錯誤信息:
未找到類型為"FUNCTION" 命名為 "CONCAT" 且具有兼容自變量的已授權例程

如果要進行多個字符串的拼接的話,可以使用多個CONCAT()函數嵌套使用,上面的SQL可以如下改寫:
SELECT CONCAT(CONCAT(CONCAT(‘工號為‘,FNumber),‘的員工姓名為‘),FName) FROM
T_Employee
WHERE FName IS NOT NULL

DB2 字符串拼接 在字段前加0操作 0||‘字段名稱’