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