Sql Server 类型转换的一个小坑
时 间:2016-07-22 08:11:34
作 者:缪炜 ID:24010 城市:江阴
摘 要:没留意过 SQL Server 中的类型转换。 写了句 SQL 来拼接字符串,期望着像常见的编程语言一样, "字符串" + "非字符串" 得到 "拼接后的字符串"。但实际上 SQL Server 只会把 字符串转为非字符串的类型,再进行相加。
正 文:
例如:
<!-- lang: sql --> Select 3 + '*';
输出:
Msg 245, Level 16, State 1, Line 1
在将 varchar 值 '*' 转换成数据类型 int 时失败。
Select '*' + 3;
输出:
Msg 245, Level 16, State 1, Line 1
在将 varchar 值 '*' 转换成数据类型 int 时失败。
Select '3' + GETDATE();
输出:
Msg 241, Level 16, State 1, Line 1
从字符串向 datetime 转换时失败。
一般来说,SQL Server 中字母和符号是不能转成数值类型的,例如:
<!-- lang: sql --> Select CAST('*' AS INT);
输出:
Msg 245, Level 16, State 1, Line 1
在将 varchar 值 '*' 转换成数据类型 int 时失败。
但是, '+' 和 '-' 这两个符号例外,它俩可以被转为数值类型,并且值都为0。
<!-- lang: sql --> Select CAST('+' AS INT), CAST('-' AS INT), CAST('' AS INT);
输出:
0 0 0
原因是 SQL Server 在转换时把 '-' 当作 '-0' ,'+' 当作 '+0' , '' 当作 '0' 来看待。
Access软件网QQ交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 【Access高效办公】按日期...(06.12)
- 合并列数据到一个文本框的示例;...(05.06)
- 通过命令按钮让Access列表...(04.24)
- 统计当月之前(不含当月)的记录...(03.11)
- 【Access Inputbo...(03.03)
- 按回车键后光标移动到下一条记录...(02.12)
- 【Access Dsum示例】...(02.07)
- Access对子窗体的数据进行...(02.05)
- 【Access高效办公】上月累...(01.09)

学习心得
最新文章
- Access快速开发平台--Acc...(06.16)
- 【Access高效办公】按日期区间...(06.12)
- Access快速开发平台--生成复...(06.07)
- 仓库管理实战课程(25)-导航菜单...(06.06)
- 仓库管理实战课程(24)-库存月结...(06.05)
- 分享一个简单的X氏家谱小示例(06.04)
- 仓库管理实战课程(23)-先入先出(06.02)
- 仓库管理实战课程(22)-代理商库...(05.30)
- 仓库管理实战课程(21)-安全库存...(05.28)
- Access快速开发平台--如何添...(05.26)