【Sqlserver系列】CAST和CONVERT
1 概述
本篇文章主要讲解SqlServer中类型转换涉及的两个函数:CAST和CONVERT。
2 具体内容
2.1 CAST
(1)作用:将一种数据类型的表达式转换为另一种数据类型的表达式。
(2)定义:
CAST ( expression AS data_type)
Parameters:
expression:任何可转换为 data_type 的有效表达式;
data_type:系统提供的目标数据类型。 该类型必须为基元(标量)类型。 使用的 data_type 取决于查询空间。 如果使用EntityCommand 执行查询,则数据类型为概念模型中定义的类型。
Return Value::
返回与 data_type 相同的值。
(3)例子
SELECT CAST('' AS INT) --
SELECT CAST(2017 AS INT) --
SELECT CAST(2017.3 AS INT) --
SELECT CAST('2017.3' AS INT)--消息 245,级别 16,状态 1,第 1 行,在将 varchar 值 '2017.3' 转换成数据类型 int 时失败。
SELECT CAST('2017.3' AS decimal) --
SELECT CAST('2017.3' AS decimal(8,2)) --2017.30
2.2 CONVERT
(1)作用:将一种数据类型的表达式转换为另一种数据类型的表达式。
(2)定义:
CONVERT ( data_type [ ( length ) ] , expression [ , style ] )
Parameters:
expression:任何有效的表达式;
data_type:目标数据类型。这包括 xml、bigint 和 sql_variant。不能使用别名数据类型;
length:指定目标数据类型长度的可选整数。默认值为 30;
style:指定 CONVERT 函数如何转换 expression 的整数表达式。如果样式为 NULL,则返回 NULL。该范围是由 data_type 确定的。有关详细信息,请参阅“备注”部分;
Return Value:
返回转换为 data_type 的 expression。
(3)例子
SELECT CONVERT(INT,'') -- SELECT CONVERT(INT,2017.3) -- SELECT CONVERT(INT,'2017.3') --消息 245,级别 16,状态 1,第 1 行,在将 varchar 值 '2017.3' 转换成数据类型 int 时失败。 SELECT CONVERT(decimal,'2017.3') -- SELECT CONVERT(decimal(8,2),'2017.3') --2017.30
2.3 CAST和CONVERT比较
(1)cast一般更容易使用,convert的优点是可以格式化日期和数值;
(2)convert一般用于日期和时间值,小数之间转换,cast一般用于小数转数值和字符型;
(3)converk显示转换,cast是强制转换;
(4)例子
select CONVERT(varchar, getdate(), 120 ) --2017-08-13 03:56:14 select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',''),':','') -- select CONVERT(varchar(12) , getdate(), 111 ) --2017/08/13 select CONVERT(varchar(12) , getdate(), 112 ) -- select CONVERT(varchar(12) , getdate(), 102 ) --2017.08.13 select CONVERT(varchar(12) , getdate(), 101 ) --08/13/2017 select CONVERT(varchar(12) , getdate(), 103 ) --13/08/2017 select CONVERT(varchar(12) , getdate(), 104 ) --13.08.2017 select CONVERT(varchar(12) , getdate(), 105 ) --13-08-2017 select CONVERT(varchar(12) , getdate(), 106 ) --13 08 2017 select CONVERT(varchar(12) , getdate(), 107 ) --08 13, 2017 select CONVERT(varchar(12) , getdate(), 108 ) --03:57:39 select CONVERT(varchar(12) , getdate(), 109 ) --08 13 2017 select CONVERT(varchar(12) , getdate(), 110 ) --08-13-2017 select CONVERT(varchar(12) , getdate(), 113 ) --13 08 2017 0 select CONVERT(varchar(12) , getdate(), 114 ) --03:58:08:200 select getdate() --2017-08-13 03:58:48.660 select convert(char(8),getdate(),112) -- select convert(char(8),getdate(),108) --03:58:48 select convert(char(8),getdate(),112) --
参考表:

3 参考文献
【01】https://msdn.microsoft.com/zh-cn/library/bb399172(v=vs.110).aspx
【02】https://technet.microsoft.com/zh-cn/library/ms187928(v=sql.105).aspx
4 版权
- 感谢您的阅读,若有不足之处,欢迎指教,共同学习、共同进步。
- 博主网址:http://www.cnblogs.com/wangjiming/。
- 极少部分文章利用读书、参考、引用、抄袭、复制和粘贴等多种方式整合而成的,大部分为原创。
- 如您喜欢,麻烦推荐一下;如您有新想法,欢迎提出,邮箱:2016177728@qq.com。
- 可以转载该博客,但必须著名博客来源。
【Sqlserver系列】CAST和CONVERT的更多相关文章
- SqlServer基础:类型转换Cast和Convert
在SqlServer要对不同类型的数据进行运算时,需要将其转换为相同类型之后再做操作,而SqlServer中有两个函数可以进行数据转换,即:Cast和Convert 1.Cast CAST(expre ...
- SQL SERVER CAST 和 CONVERT 函数
遇到CAST 函数转化数字不一致情况, select CAST('0000000011237590798' AS money) / 100 AS Amount--output : 112375907. ...
- CAST和CONVERT差别与联系
CAST和CONVERT:都是将一种数据类型转换成为另一种数据类型. CAST: CAST ( expression AS data_type [ ( length ) ] ) EG: )) ) as ...
- SQL之 CAST 和 CONVERT
原文来自于: http://bbs.csdn.net/topics/330251394 CAST 和 CONVERT将某种数据类型的表达式显式转换为另一种数据类型.CAST 和 CONVERT 提供相 ...
- SQL 语句转换格式函数Cast、Convert
CAST和CONVERT都经常被使用.特别提取出来作为一篇文章,方便查找. CAST.CONVERT都可以执行数据类型转换.在大部分情况下,两者执行同样的功能,不同的是CONVERT还提供一些特别的日 ...
- MySQL 字符串 转 int/double CAST与CONVERT 函数的用法
http://hongmin118.iteye.com/blog/2029728 转的 MySQL 的CAST()和CONVERT()函数可用来获取一个类型的值,并产生另一个类型的值.两者具体的语 ...
- SQL 语句转换格式函数Cast、Convert 区别
SQL 语句转换格式函数Cast.Convert CAST和CONVERT都经常被使用.特别提取出来作为一篇文章,方便查找. CAST.CONVERT都可以执行数据类型转换.在大部分情况下,两者执行同 ...
- SQL Server 基础:Cast和Convert的区别
CAST 和 CONVERT 都可以将某种数据类型的表达式显式转换为另一种数据类型. 语法: CAST ( expression AS data_type ) CONVERT (data_type[( ...
- MySQL CAST与CONVERT 函数的用法
MySQL CAST与CONVERT 函数的用法 产生另一个类型的值 MySQL 的CAST()和CONVERT()函数可用来获取一个类型的值,并产生另一个类型的值. 两者具体的语法如下:1 CAS ...
随机推荐
- spring AOP 和自定义注解进行身份验证
一个SSH的项目(springmvc+hibernate),需要提供接口给app使用.首先考虑的就是权限问题,app要遵循极简模式,部分内容无需验证,用过滤器不能解决某些无需验证的方法 所以最终选择用 ...
- [转载] Hadoop和Hive单机环境搭建
转载自http://blog.csdn.net/yfkiss/article/details/7715476和http://blog.csdn.net/yfkiss/article/details/7 ...
- Ext3和Ext4文件系统区别
inode http://www.cnblogs.com/itech/archive/2012/05/15/2502284.html Ex3使用15个inode查询数据块,前12个为直接数据块,直接指 ...
- cgg之数据类型
所有例子都在64为操作系统 Linux 2.6.30 x86_64 x86_64 x86_64 GNU/Linux 1.1整数 在stdint.h中定义一些看上去更明确的整数类型 #ifndef __ ...
- MySQL5.5编译安装以及Debug
MySQL5.5以上版本安装是需要cmake 安装步骤: 设置编译参数cmake -DCMAKE_INSTALL_PREFIX='/data1/guosong/mysql_debug' -DDEF ...
- 关于Python在Linux、Mac和Windows上的安装方法总结
一.Linux下安装python 1.python源码安装包下载地址: https://www.python.org/downloads/source/ 2.下载完tar.xz压缩包以后, ...
- Vuejs-组件-<slot> 标签分发内容
资料来自:https://cn.vuejs.org/v2/guide/components.html#具名-Slot 在官方文档的基础上,更加细致的讲解代码. <slot> 标签中的任何内 ...
- OC的内存管理和@class
1. 基本原理 1. 什么是内存管理 ➢ 移动设备的内存极其有限,每个app所能占用的内存是有限制的 ➢ 当app所占用的内存较多时,系统会发出内存警告,这时得回收一些不需要再使用的内存空间.比如回收 ...
- Java项目之员工收录系统
在Java SE中,对IO流与集合的操作在应用中比较重要.接下来,我以一个小型项目的形式,演示IO流.集合等知识点在实践中的运用. 该项目名称为"员工收录系统",在Eclipse的 ...
- 求知的木头 Cannot load browser "PhantomJS": it is not registered! Perhaps you are missing some plugin? 测试安装遇到的BUG
原文链接 求知的木头 Cannot load browser "PhantomJS": it is not registered! Perhaps you are missin ...