网站首页 > 技术文章 正文
程序员,在sqlserver中,我们常用的数据类型转换函数有cast()和convert()。
1.cast()函数:
用法:
cast(字段名 as 转换的类型),比如:
select cast(188.88 as int) --188,将float类型转换为int类型
select cast('188.88' as decimal) --189,decimal只会保留整数部分
select cast('188.88' as decimal(8,2)) --188.88,将char类型转换为数值类型,8为精度,代表除小数点外,最长为8位;2为小数位数,代表小数点后面保留两位小数。
select cast('188.888888' as decimal(6,3)) --188.89,将varchar类型转换为数值类型,6为精度,代表除小数点外,最长为6位;3为小数位数,代表小数点后面保留3位小数。
select cast('20240526' as date) --2024-05-26 将字符串类型转换为日期类型
select cast('20240526' as datetime) --2024-05-26 00:00:00.000 将字符串转换为日期时间类型
select cast(getdate() as time) --21:47:32.1166667 取当前的时间信息,不保留日期信息
2.convert()函数,convert(目标数据类型,需要转换的值,输出的格式(可选))
select convert(int,28.88) --28,将float类型转换为int类型
select convert(decimal,'28.88') --29,将字符串转换为decimal类型,默认小数位是0
select convert(decimal(6,2),'28.888') --28.89,将字符串转换为decimal类型,小数位保留2位,所以是28.89
select convert(varchar(50),getdate(),120) --2024-05-26 22:01:16,最常用,保留日期时间信息
select convert(varchar(10),getdate(),102) --2024.05.26,只保留日期信息
select convert(varchar(10),getdate(),111) --2024/05/26,只保留日期信息
select convert(varchar(10),getdate(),108) --22:03:18,只保留时间信息
当然,在sqlserver数据库中除了cast()和convert()常用的类型转换函数外,还有parse(),try_parse(),try_cast(),try_convert()。带try前缀的,表示当类型转换失败时,返回NULL值。
select parse('188' as int) --188,将字符串转换为int类型
select try_parse('188.88' as int) --NULL,转换失败则返回NULL
select try_cast('188.88' as decimal) --189,将字符串转换为decimal类型,默认保留0位小数,如果转换失败,返回NULL
select try_cast('188.88' as int) --NULL,转换失败,返回NULL
select try_convert(decimal(5,2),'188.8888') --188.89,将字符串转换为decimal类型,保留2位小数
select try_convert(decimal(5,2),'国内实力派程序员') --NULL,转换失败,返回NULL
我们程序员在做类型转换的时候要注意这3点:
1.类型转换可能会失败,尤其是在转换不兼容的数据类型时(例如,将字符串转换为整数时字符串不是有效的整数格式)。
2.转换函数可能会影响性能,尤其是在处理大量数据时。
3.在进行类型转换时,需要注意数据精度和范围,以避免数据丢失或溢出。
猜你喜欢
- 2025-03-26 Java web后端转Java游戏后端(java转web前端)
- 2025-03-26 c语言数据类型与变量详解(c语言的数据类型及其定义方法)
- 2025-03-26 西门子SCL高级语言之数据转换介绍
- 2025-03-26 三菱——转换指令(三菱转移指令怎么写)
- 2025-03-26 C语言堆栈应用之逆波兰法表达式求值
- 2025-03-26 C#中实现byte数组与其他数据类型之间相互转换的通用方法
- 2025-03-26 6.4 数据类型转换(数据类型转换的规则是什么)
- 2025-03-26 Python常见数据类型转换(python数据类型转换规则)
- 2025-03-26 三菱PLC中常见的数据类型转换(三菱plc转换后再怎么编辑)
- 2025-03-26 【C编程问题集中营】在不同编译器下float强转为无符号int的表现
- 08-06中等生如何学好初二数学函数篇
- 08-06C#构造函数
- 08-06初中数学:一次函数学习要点和方法
- 08-06仓颉编程语言基础-数据类型—结构类型
- 08-06C++实现委托机制
- 08-06初中VS高中三角函数:从"固定镜头"到"360°全景",数学视野升级
- 08-06一文讲透PLC中Static和Temp变量的区别
- 08-06类三剑客:一招修改所有对象!类方法与静态方法的核心区别!
- 1531℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 698℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 536℃MySQL service启动脚本浅析(r12笔记第59天)
- 502℃启用MySQL查询缓存(mysql8.0查询缓存)
- 500℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 487℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 469℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 467℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- windowsscripthost (69)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (70)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)