SQL中字元串拼接

来源:http://www.cnblogs.com/rainman/archive/2016/12/20/6203065.html
-Advertisement-
Play Games

1. 概述 在SQL語句中經常需要進行字元串拼接,以sqlserver,oracle,mysql三種資料庫為例,因為這三種資料庫具有代表性。 sqlserver: oracle: mysql: 註意:SQL Server中沒有concat函數。oracle和mysql中雖然都有concat,但是or ...


1. 概述

在SQL語句中經常需要進行字元串拼接,以sqlserver,oracle,mysql三種資料庫為例,因為這三種資料庫具有代表性。

sqlserver:

select '123'+'456';

oracle:

select '123'||'456' from dual;
或
select concat('123','456') from dual;

mysql:

select concat('123','456');

註意:SQL Server中沒有concat函數(SQL Server 2012已新增concat函數)。oracle和mysql中雖然都有concat,但是oracle中只能拼接2個字元串,所以建議用||的方式;mysql中的concat則可以拼接多個字元串。

在SQL Server中的“+”號除了能夠進行字元串拼接外,還可以進行數字運算,在進行字元串拼接時要小心使用。下麵以“Users”表為例,進行詳細分析:

2. 數字 + 字元串

2.1 int + varchar

SELECT id + place FROM Users WHERE id = 1;  //提示錯誤“在將 varchar 值 'bzz' 轉換成數據類型 int 時失敗”
SELECT id + place FROM Users WHERE id = 5;  //提示錯誤“在將 varchar 值 '102.34' 轉換成數據類型 int 時失敗”
SELECT id + place FROM Users WHERE id = 4;	//返回int “105”

2.2 decimal + varchar

SELECT *, id + cost  FROM Users WHERE id = 4 OR id = 5;	//返回decimal “102.98”和“104.30”
SELECT *, place + cost FROM Users WHERE id = 1;	//提示錯誤“從數據類型 varchar 轉換為 numeric 時出錯。”

由此可見,系統會將字元串varchar類型轉化為int,若不能轉換則提示錯誤,轉換成功則進行數字計算。

3. 數字 + 數字

數字指的是int、decimal等類型。數字 +  數字,則進行數字相加,若某欄位為NULL,則計算結果為NULL。

SELECT *,  uage + cost AS 'uage + cost'  FROM Users

4.字元串 + 字元串

字元串 + 字元串,則直接進行拼接。若某欄位為NULL,則計算結果為NULL。

SELECT *, uname + place AS 'uname + place' FROM Users 

5. 使用CAST和CONVERT函數進行類型轉換

通過上述實例,可以看出若要使用“+”進行字元串拼接或數字計算,最穩妥的方法是進行類型轉換。

  • CAST()函數可以將某種數據類型的表達式轉化為另一種數據類型
  • CONVERT()函數也可以將制定的數據類型轉換為另一種數據類型

要求:將“678”轉化為數值型數據,並與123相加進行數學運算。

SELECT CAST('678' AS INT) + 123;
SELECT CONVERT(INT, '678') + 123;

要求:id列和place列進行字元串拼接。

SELECT *, CONVERT(varchar(10), id) + place FROM Users;

字元串拼接後的字元串不能簡單作為“篩選欄位”

有時,需要列A = 變數1,列B = 變數2的篩選,為了簡化SQL語句 列A + 列B = 變數1 + 變數2。這種方法並不完全準確

SELECT * FROM Users WHERE uname + place = 'aabzz';

SELECT * FROM Users WHERE uname = 'aa' AND place = 'bzz';

為了防止上述情況的發生,可以再列A和列B之間加上一個較特殊的字元串。

SELECT * FROM Users WHERE uname + 'rain@&%$man' + place = 'aa' + 'rain@&%$man' + 'bzz'

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

-Advertisement-
Play Games
更多相關文章
  • 最簡單的意思就是在sql server中定義了一系列操作的的一個過程,只要調用他就可以完成相應的操作. 存儲過程定義: 將常用的或很複雜的工作,預先用SQL語句寫好並用一個指定的名稱存儲起來, 那麼以後要叫資料庫提供與已定義好的存儲過程的功能相同的服務時,只需調用execute,即可自動完成命令。 ...
  • 之前因為項目的原因需要使用Oracle資料庫,由於時間有限沒辦法從基礎開始學習,而且oracle操作的命令界面又太不友好,於是就找到了PL/SQL Developer這個很好用的軟體來間接使用資料庫。 下麵簡單介紹一下如何用這個軟體連接Oracle資料庫。 第一步 安裝Oracle Database ...
  • 在前一篇文章中,我們已經搭建好了Hadoop的群集,接下來,我們就是需要基於這個Hadoop群集,搭建Spark的群集。由於前面已經做了大量的工作,所以接下來搭建Spark會簡單很多。 首先打開三個虛擬機,現在我們需要安裝Scala,因為Spark是基於Scala開發的,所以需要安裝Scala。在U ...
  • 一、前言 mysql的InnoDB,支持事務和行級鎖,可以使用行鎖來處理用戶提現等業務。使用mysql鎖的時候有時候會出現死鎖,要做好死鎖的預防。 二、MySQL行級鎖 行級鎖又分共用鎖和排他鎖。 共用鎖: 名詞解釋:共用鎖又叫做讀鎖,所有的事務只能對其進行讀操作不能寫操作,加上共用鎖後其他事務不能 ...
  • 1. 主鍵 超鍵 候選鍵 外鍵 主 鍵: 資料庫表中對儲存數據對象予以唯一和完整標識的數據列或屬性的組合。一個數據列只能有一個主鍵,且主鍵的取值不能缺失,即不能為空值(Null)。 超 鍵: 在關係中能唯一標識元組的屬性集稱為關係模式的超鍵。一個屬性可以為作為一個超鍵,多個屬性組合在一起也可以作為一 ...
  • 下麵是例子分析表A記錄如下: aID aNum 1 a20050111 2 a20050112 3 a20050113 4 a20050114 5 a20050115 表B記錄如下: bID bName 1 2006032401 2 2006032402 3 2006032403 4 2006032 ...
  • 例如: id name value 1 a pp 2 a pp 3 b iii 4 b pp 5 b pp 6 c pp 7 c pp 8 c iii id是主鍵 要求得到這樣的結果 id name value 1 a pp 3 b iii 4 b pp 6 c pp 8 c iii 方法1 del ...
  • MySQL慢查詢配置 1. 慢查詢有什麼用? 它能記錄下所有執行超過long_query_time時間的SQL語句, 幫你找到執行慢的SQL, 方便我們對這些SQL進行優化. 2. 如何開啟慢查詢? 首先我們先查看MYSQL伺服器的慢查詢狀態是否開啟.執行如下命令: show variables l ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...