轉換函數

来源:http://www.cnblogs.com/Gin-23333/archive/2016/02/13/5187499.html
-Advertisement-
Play Games

一般來說,轉換函數大家並不陌生。就是使用cast 和 convert 進行數據類型的轉換來達到表達式的比較,語句的拼接等效果。 使用倒是很容易的。一般情況下這樣使用就可以了。 SELECT CONVERT(INT,'123') SELECT CAST('123' AS INT) 還有一個比較少用的,


一般來說,轉換函數大家並不陌生。就是使用cast 和 convert 進行數據類型的轉換來達到表達式的比較,語句的拼接等效果。

使用倒是很容易的。一般情況下這樣使用就可以了。

SELECT CONVERT(INT,'123')
SELECT CAST('123' AS INT)

還有一個比較少用的,parse 函數。(PARSE 僅用於從字元串轉換為日期/時間和數字類型。 對於一般的類型轉換,請繼續使用 CAST 或 CONVERT。 請記住,分析字元串值會帶來一定的性能開銷,這句是文檔裡面直接抄下來的)

既然有了 Convert 和 Cast ,為什麼還需要一個 parse 函數呢?比如說有下麵一種情況,我們一看就知道是2016年1月1日,但是使用Convert 和cast 就會報轉換失敗了,因為無法直接轉換成對應的日期格式。那麼這時候就要使用 parse 函數就可以了~然而parse 函數雖然方便,但是一般情況下並不推薦使用,因為使用parse函數設計到裡面的字元分析,會帶來性能開銷

(Parse函數的說明  https://msdn.microsoft.com/zh-cn/library/hh213316(v=sql.120).aspx)

SELECT CONVERT(DATETIME,'2016年1月1日')
SELECT CAST('2016年1月1日' AS DATETIME)

SELECT CONVERT(DATETIME,'2016Jan01')
SELECT CAST('2016Jan01' AS DATETIME)

 

SELECT PARSE('01Jan2016' AS DATETIME USING 'en-US')
SELECT PARSE('2016Jan01' AS DATETIME USING 'en-US')
SELECT PARSE('2016年1月1日' AS DATETIME USING 'zh-CN')


-----------------------
2016-01-01 00:00:00.000

-----------------------
2016-01-01 00:00:00.000

-----------------------
2016-01-01 00:00:00.000

 

然而雖然有了轉換的函數,但是有時候轉換失敗的時候還是會比較蛋疼的。比方說有時候一般來說我知道這列是一個varchar(50),但是裡面全部存儲的都是錢,那我就信心滿滿的使用一個 

select convert(money , Column1) from table 

這樣的語句,殊不知裡面其中有一條數據寫著 100CNY 那這個轉換函數就死翹翹了。要不你就只能做類似的判斷來防止了。

select case when ISNUMERIC(Column1) = 1 THEN convert(MONEY , Column1) ELSE NULL END FROM Table

 

而到了2012以上的版本,Sql Server 支持了使用 

Try_Convert()

Try_Cast()

Try_Parse() 

3種函數,用法和 Convert,Cast ,Parse 一致,不一樣的地方在於,如果轉換失敗並不會拋錯,只會返回Null值,這樣紙在某些場景還是可以省下不少功夫。還是比較推薦使用的~

哦~補充一句,祝各位新年快樂~添丁發財

 


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

-Advertisement-
Play Games
更多相關文章
  • 目前android很多開源的網路通信庫大多是基於http, 像Volley, android-async-http等等,在WAN上的網路通信是個不錯的解決方案,而對於在區域網內的通信場景,上面基於http的網路通信仍然有效,但是並非所有的服務端都採用http服務,MirrorNetwork正是在這個
  • 自定義tabbar高度的跳轉隱藏問題 === 問題並不是很複雜,只是需求特殊,在網上沒有找到類似的demo,網上也有很多blog或者技術文章都有自己的見解,還沒有找到能完的解決我的需求的方法,這個問題從年前一直想到年後,想了大概一禮拜吧。。。終於解決!!! 在網上也找到很多大神的博客,辯論自定義ta
  • 前言: 首先展示一下這個iOS小示例的彩色進度條動畫效果: 閱讀本文先說說好處:對於基礎不好的讀者,可以直接閱讀文末尾的"如何使用彩虹動畫進度條"章節,然後將我封裝好的這個功能模塊類用到你的工程項目中即可。 這個效果的示例是老外Nick Jensen在2013年寫的一個作品:使用CAGradient
  • 字元串查找。在模糊朝找的情況下,其實3者的效率是差不多的。都需要一個一個取出來然後掃一遍╮(╯_╰)╭。然而用法還是會有一點兒的區別 1 charindex (查找的字元串,字元串表達式[,開始查找的位置]) ,簡單來說用法就是這樣紙。然而這個函數對 text,ntext,image 類型無效,並且
  • 現在網上絕大多數網站都是ACCESS+ASP的形式,因為ACCESS結構簡單容易處理,而且也能滿足多數的網站程式要求。 ACCESS是小型資料庫,既然是小型就有他根本的局限性,以下幾種情況下資料庫基本上會吃不消: 1。資料庫過大,一般ACCESS資料庫達到50M左右的時候性能會急劇下降! 2。網站訪
  • 1、delete:刪除數據表中的行(可以刪除某一行,也可以在不刪除數據表的情況下刪除所有行) 刪除某一行:delete from 數據表名稱 where 列名稱=值; 刪除所有行:delete*from 數據表名稱 2、drop:刪除數據表或資料庫或數據表欄位 刪除資料庫:drop database
  • 1、exists:sql返回結果集為真;not exists:sql不返回結果集為真。詳解過程如圖: exists not exists
  • 1、show warnings:顯示上一個語句的錯誤、警告以及註意。如圖:
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...