SQL Server數據類型轉換方法

来源:https://www.cnblogs.com/yoga21/archive/2018/04/11/8796863.html
-Advertisement-
Play Games

在SQL Server日常的函數、存儲過程和SQL語句中,經常會用到不同數據類型的轉換。在SQL Server有兩種數據轉換類型:一種是顯性數據轉換;另一種是隱性數據轉換。下麵分別對這兩種數據類型轉換進行簡要的說明: 1 顯式轉換 顯示轉換是將某種數據類型的表達式顯式轉換為另一種數據類型。常用的是C ...


在SQL Server日常的函數、存儲過程和SQL語句中,經常會用到不同數據類型的轉換。在SQL Server有兩種數據轉換類型:一種是顯性數據轉換;另一種是隱性數據轉換。下麵分別對這兩種數據類型轉換進行簡要的說明:

1 顯式轉換

顯示轉換是將某種數據類型的表達式顯式轉換為另一種數據類型。常用的是CAST 和 CONVERT 函數。

CAST: CAST ( expression AS data_type )
CONVERT: CONVERT (data_type[(length)], expression [, style])

參數 expression 是任何有效的 Microsoft SQL Server表達式。data_type 目標系統所提供的數據類型,不能使用用戶定義的數據類型。

2 隱性轉換

隱性轉換對於用戶是不可見的,由SQL Server 引擎自動處理。 隱性轉換自動將數據從一種數據類型轉換成另一種數據類型。例如,如果一個 smallint 變數和一個 int 變數相比較,這個 smallint 變數在比較前即被隱性轉換成 int 變數。 當從一個 SQL Server 對象的數據類型向另一個轉換時,一些隱性和顯式數據類型轉換是不支持的。例如,nchar 數值根本就不能被轉換成 image 數值。nchar 只能顯式地轉換成 binary,隱性地轉換到 binary 是不支持的。nchar 可以顯式地或者隱性地轉換成 nvarchar。

3 隱性轉換的風險

隱性轉換有的時候非常方便,可以簡化SQL 腳本,但是這裡面也孕育著潛在的風險,可能會出現在腳本一開始運行的時候都是正常的,但卻某一個時間點之後,程式莫名出現錯誤。下麵舉一個現實項目中的例子來說明。在SQL Server 2008中有一個表,需要從兩個不同的數據表中拉取數據,由於這兩個數據表屬於不同的系統,其主鍵類型是不同的,一個是int類型,一個是GUID,一開始想著這兩個都可以轉換成字元類型進行存儲。所以就在表中建立一個nvarchar(50)的混合ID列作為主鍵。如下圖所示:

一開始拉取的數據並未有GUID的值,都是INT類型轉換過來的數據,所以SQL腳本運行的正常,但是突然某一次運行時,出現了“在將 nvarchar 值 '4C185367-F004-41FE-8A0A-DB4E819B1FF2' 轉換成數據類型 int 時失敗。”的錯誤。如下圖所示:

定位到腳本,執行的SQL如下:

select * from dbo.Demo where 混合ID=305

其中主鍵中的數據有GUID轉換的字元型,也有INT轉換的字元串,示例數據如下:

但是如果執行下麵的SQL,則都是正常執行:

  1. select * from dbo.Demo where 混合ID=305 and 名稱='INT'
  2. select * from dbo.Demo where 混合ID=305 and 序號='2'
  3. select * from dbo.Demo where 混合ID=305 and 序號=2
  4. select * from dbo.Demo where 混合ID='305' and 名稱='INT'
  5. select * from dbo.Demo where 混合ID='305'
複製代碼

結果如下:

出現上述錯誤的結果應該是這樣的:

select * from dbo.Demo where 混合ID=305在執行時,SQL Server會將nvarchar類型的隱性轉換成int類型,如果數據中沒有GUID類型的字元,則轉換正常,如果有,當進行GUID字元到INT的隱性轉換時,則轉換失敗。

 

轉載自:https://blog.csdn.net/qq_37446416/article/details/54861081。


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

-Advertisement-
Play Games
更多相關文章
  • 因為今天寫了個小腳本,死活不成功,總是報文件或者目錄不存在,問了一下我們馬同學的正常寫法,發現只有腳本頭的區別,也就是今天本文要講的 !/bin/sh與 !/bin/bash. 本文參考:https://www.cnblogs.com/aaronLinux/p/6885288.html和http:/ ...
  • 今天在linux下創建了一個項目自動化發佈的腳本,在執行到 mvn clean package -Dmaven.test.skip=true 的時候,項目clean失敗 查下下度娘,windows下導致原因說是文件被占用,初步懷疑linux下是許可權不夠導致,使用 sudo -i 切換到root用戶下 ...
  • 修改完nginx配置後,需要使用 nginx -s reload使修改的配置生效,配置生效是平滑的,不會對訪問產生任何影響reload後會啟動新的進程接受新請求,對於未處理完的請求還是用老的配置,直到請求處理完畢,老的進行會退出 ...
  • 本文收錄在Linux運維企業架構實戰系列 環境準備 系統:CentOS 7 IP:192.168.10.101 關閉selinux 和防火牆 一、準備 Python3 和 Python 虛擬環境 1、安裝依賴包 [root@centos7-1 opt]# yum -y install wget sq ...
  • Swap分區的拓展和縮小 分為兩種方法: 一, 用磁碟直接掛在 步驟如下: 使用fdisk來創建交換分區(假設 /dev/sdb2 是創建的交換分區) 使用 mkswap 命令來設置交換分區: # mkswap /dev/sdb2 啟用交換分區: # swapon /dev/sdb2 寫入/etc/ ...
  • revit二次開發中遇到的問題 RevitAPIUI.dll 只能 Native Library 中執行; 脫離了Native Library,API是跑不起來的 。 檢查程式流程:登錄,配置,啟動revit。 在啟動revit之前不能執行RevitAPI.dll和RevitAPIUI.dll的相關 ...
  • 本文內容: 什麼是外鍵 外鍵的增加 外鍵的修改和刪除 外鍵的約束模式 首發日期:2018-04-12 什麼是外鍵: 外鍵就是表中存在一個欄位指向另外一個表的主鍵,那麼這個欄位就可以稱為外鍵。 一張表可以有多個外鍵。 外鍵用於約束表與表之間的關係,可以說外鍵是表之間的映射關係,這個關係可以幫助我們處理... ...
  • (註:sql對大小寫不敏感,附:命令行操作:cd 目錄名 可進入文件,cd .. 可返回上級木目錄) a) Select * from 表名(顯示表內所有數據) b) Select 屬性 from 表名 where 符合某條件(如id=’1’) c) Delete from 表名 where 屬性= ...
一周排行
    -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# ...