天天看點

SQL 裡的CAST CONVERT學習CAST 和 CONVERT

CAST 和 CONVERT

将某種資料類型的表達式顯式轉換為另一種資料類型。CAST 和 CONVERT 提供相似的功能。

文法

使用 CAST:

CAST ( expression AS data_type )

使用 CONVERT:

CONVERT (data_type[(length)], expression [, style])

參數

expression

是任何有效的 Microsoft® SQL Server™ 表達式。有關更多資訊,請參見表達式。

data_type

目标系統所提供的資料類型,包括 bigint 和 sql_variant。不能使用使用者定義的資料類型。有關可用的資料類型的更多資訊,請參見資料類型。

length

nchar、nvarchar、char、varchar、binary 或 varbinary 資料類型的可選參數。

style

日期格式樣式,借以将 datetime 或 smalldatetime 資料轉換為字元資料(nchar、nvarchar、char、varchar、nchar 或 nvarchar 資料類型);或者字元串格式樣式,借以将 float、real、money 或 smallmoney 資料轉換為字元資料(nchar、nvarchar、char、varchar、nchar 或 nvarchar 資料類型)。

SQL Server 支援使用科威特算法的阿拉伯樣式中的資料格式。

在表中,左側的兩清單示将 datetime 或 smalldatetime 轉換為字元資料的 style 值。給 style 值加 100,可獲得包括世紀數位的四位年份 (yyyy)。

不帶世紀數位 (yy) 帶世紀數位 (yyyy) 标準 輸入/輸出**
- 0 或 100 (*) 預設值 mon dd yyyy hh:miAM(或 PM)
1 101 美國 mm/dd/yyyy
2 102 ANSI yy.mm.dd
3 103 英國/法國 dd/mm/yy
4 104 德國 dd.mm.yy
5 105 意大利 dd-mm-yy
6 106 - dd mon yy
7 107 - mon dd, yy
8 108 - hh:mm:ss
- 9 或 109 (*) 預設值 + 毫秒 mon dd yyyy hh:mi:ss:mmmAM(或 PM)
10 110 美國 mm-dd-yy
11 111 日本 yy/mm/dd
12 112 ISO yymmdd
- 13 或 113 (*) 歐洲預設值 + 毫秒 dd mon yyyy hh:mm:ss:mmm(24h)
14 114 - hh:mi:ss:mmm(24h)
- 20 或 120 (*) ODBC 規範 yyyy-mm-dd hh:mm:ss[.fff]
- 21 或 121 (*) ODBC 規範(帶毫秒) yyyy-mm-dd hh:mm:ss[.fff]
- 126(***) ISO8601 yyyy-mm-dd Thh:mm:ss:mmm(不含空格)
- 130* 科威特 dd mon yyyy hh:mi:ss:mmmAM
- 131* 科威特 dd/mm/yy hh:mi:ss:mmmAM

*    預設值(style 0 或 100、9 或 109、13 或 113、20 或 120、21 或 121)始終傳回世紀數位 (yyyy)。

** 當轉換為 datetime 時輸入;當轉換為字元資料時輸出。

*** 專門用于 XML。對于從 datetime 或 smalldatetime 到 character 資料的轉換,輸出格式如表中所示。對于從 float、money 或 smallmoney 到 character 資料的轉換,輸出等同于 style 2。對于從 real 到 character 資料的轉換,輸出等同于 style 1。

重要  預設情況下,SQL Server 根據截止年份 2049 解釋兩位數字的年份。即,兩位數字的年份 49 被解釋為 2049,而兩位數字的年份 50 被解釋為 1950。許多用戶端應用程式(例如那些基于 OLE 自動化對象的用戶端應用程式)都使用 2030 作為截止年份。SQL Server 提供一個配置選項("兩位數字的截止年份"),借以更改 SQL Server 所使用的截止年份并對日期進行一緻性處理。然而最安全的辦法是指定四位數字年份。

當從 smalldatetime 轉換為字元資料時,包含秒或毫秒的樣式将在這些位置上顯示零。當從 datetime 或 smalldatetime 值進行轉換時,可以通過使用适當的 char 或 varchar 資料類型長度來截斷不需要的日期部分。

下表顯示了從 float 或 real 轉換為字元資料時的 style 值。

輸出
0(預設值) 最大為 6 位數。根據需要使用科學記數法。
1 始終為 8 位值。始終使用科學記數法。
2 始終為 16 位值。始終使用科學記數法。

在下表中,左清單示從 money 或 smallmoney 轉換為字元資料時的 style 值。

輸出
0(預設值) 小數點左側每三位數字之間不以逗号分隔,小數點右側取兩位數,例如 4235.98。
1 小數點左側每三位數字之間以逗号分隔,小數點右側取兩位數,例如 3,510.92。
2 小數點左側每三位數字之間不以逗号分隔,小數點右側取四位數,例如 4235.9819。
傳回類型

傳回與 data type 0 相同的值。

例子

表tabtimedata   如下:

Precipitation  

-------------  

0001

0010

-      

-      

-      

-      

-      

-      

-      

-      

-      

0003

0009

0003

-      

-      

-      

0001

-      

-      

0001

-      

0002

0003

我想得到最大最小值,當   Precipitation為'-'時則為0,該怎麼寫?

--這是我寫的,不對

select     Max(cast(Precipitation   as   real))   as   最大   ,Min(cast(Precipitation   as   real))   as   最小   from   tabtimedata   --//where     Precipitation <> '-'

我要的結果為

最大     最小

10           0

SQL code

declare @tb table (p varchar(10))

insert into @tb select '0001'

insert into @tb select '0001'

insert into @tb select '-'

insert into @tb select '-'

insert into @tb select '-'

insert into @tb select '-'

insert into @tb select '*'

insert into @tb select '0003'

insert into @tb select '0009'

select max(p),min(p) from(

select cast((case when p='-' then '0' when p='*' then '10' else p end) as int)as p from @tb) t

多條件判斷case .. when ..when ...else ...as