在SQLSERVER2005中,将表中字符串转换为数字的函数共2个:1.convert(int,字段名)例如:selectconvert(int,'3')2.cast(字段名asint)例如:selectcast('3'asint)其实,一般情况下没有必要把字符串转换为数字类型假如需要比较两个字段是否相等,但是一个字段为字符串类型,一个为数字类型,用“=”比较两个值是否相等时,SQLSERVER会自动把字符串转换为数字再比较的!例如:selectda.TITLE_NAME,dsc.NAMEfromdbo.DV_DUTYddinnerjoinDV_SECOND_CLASSdscon(dsc.ID=dd.AREA)leftjoinDV_ASSETdaon(da.ID=dd.RECORD_IDanddd.TYPE='2')wheredd.AREAisnotnull这个SQl中,innerjoinDV_SECOND_CLASSdscon(dsc.ID=dd.AREA)中dsc.ID为数字类型,dd.AREA为字符类型,相当于这样on(1='1')的判断,这时候就会自动吧字符串的'1'转换为数字类型再比较的。但是也有弊端,一旦字符类型转换为数字类型出错(说明字符串的确就非数字组成的),SQL就会抛出异常。SQLSERVER2005中有判断字段是否为数字的函数:ISNUMERIC(字段名)-----假如字段是数字类型返回1,不是就返回0但是好像有的时候不好使,比如:selectisnumeric('3,34')就返回1说明这个函数对字段值中全是数字但是数字间用“,”和“.”(逗号或点)隔开的都视为数字了!
1. AVG 返回指定组中的平均值,空值被忽略。
例:select prd_no,avg(qty) from sales group by prd_no
2. COUNT 返回指定组中项目的数量。
例:select count(prd_no) from sales
3. MAX 返回指定数据的最大值。
例:select prd_no,max(qty) from sales group by prd_no
4. MIN 返回指定数据的最小值。
例:select prd_no,min(qty) from sales group by prd_no
5. SUM 返回指定数据的和,只能用于数字列,空值被忽略。
例:select prd_no,sum(qty) from sales group by prd_no