sqlserver轉(zhuǎn)換數(shù)據(jù)類型 sqlserver中如何把數(shù)字轉(zhuǎn)換成時間的格式?
sqlserver中如何把數(shù)字轉(zhuǎn)換成時間的格式?(4)datename函數(shù) 返回代表指定日期的指定日期部分的字符串。另一方面就是我們常常需要將得到的日期結(jié)果轉(zhuǎn)換成我們想要的格式,而日期函數(shù)中沒有提供這
sqlserver中如何把數(shù)字轉(zhuǎn)換成時間的格式?
(4)datename函數(shù) 返回代表指定日期的指定日期部分的字符串。另一方面就是我們常常需要將得到的日期結(jié)果轉(zhuǎn)換成我們想要的格式,而日期函數(shù)中沒有提供這樣或那樣我們想要的格式,那么我們就要用到convert函數(shù)了,基本上所有的轉(zhuǎn)換格式的問題都可以用它來幫助我們解決。當(dāng)然cast函數(shù)在一定程度上也可以做到,但并不像convert那樣盡如人意。
sqlserver中如何把字符串轉(zhuǎn)換成數(shù)字?
在SQL SERVER 2005中,將表中字符串轉(zhuǎn)換為數(shù)字的函數(shù)共2個:
1. convert(int,字段名) 例如:select convert(int,"3")
2. cast(字段名 as int) 例如:select cast("3" as int)
其實,一般情況下沒有必要把字符串轉(zhuǎn)換為數(shù)字類型
假如需要比較兩個字段是否相等,但是一個字段為字符串類型,一個為數(shù)字類型,用“=”比較兩個值是否相等時,SQL SERVER會自動把字符串轉(zhuǎn)換為數(shù)字再比較的!
例如:
select da.TITLE_NAME,dsc.NAME
from dbo.DV_DUTY dd
inner join DV_SECOND_CLASS dsc on (dsc.ID=dd.AREA)
left join DV_ASSET da on(da.ID=dd.RECORD_ID and dd.TYPE="2")
where dd.AREA is not null
這個SQl中,inner join DV_SECOND_CLASS dsc on (dsc.ID=dd.AREA) 中dsc.ID為數(shù)字類型,dd.AREA為字符類型,相當(dāng)于這樣on(1="1")的判斷,這時候就會自動吧字符串的"1"轉(zhuǎn)換為數(shù)字類型再比較的。
但是也有弊端,一旦字符類型轉(zhuǎn)換為數(shù)字類型出錯(說明字符串的確就非數(shù)字組成的),SQL就會拋出異常。
SQL SERVER 2005中有判斷字段是否為數(shù)字的函數(shù):
ISNUMERIC(字段名) -----假如字段是數(shù)字類型返回1,不是就返回0
但是好像有的時候不好使,比如:select isnumeric("3,34") 就返回1
說明這個函數(shù)對字段值中全是數(shù)字但是數(shù)字間用“,”和“.”(逗號或點)隔開的都視為數(shù)字了!