[Mysql] CAST函数
CAST函数用于将值从一种数据类型转换为表达式中指定的另一种数据类型
语法
CAST(value AS datatype)
AS关键字用于分隔两个参数,在AS之前的是要处理的数据,在AS之后的是要转换的数据类型
参数说明
value: 要转换的值
datatype: 要转换成的数据类型
值 | 描述 |
DATE | 将value转换成'YYYY-MM-DD'格式 |
DATETIME | 将value转换成'YYYY-MM-DD HH:MM:SS'格式 |
TIME | 将value转换成'HH:MM:SS'格式 |
CHAR | 将value转换成CHAR(固定长度的字符串)格式 |
SIGNED | 将value转换成INT(有符号的整数)格式 |
UNSIGNED | 将value转换成INT(无符号的整数)格式 |
DECIMAL | 将value转换成FLOAT(浮点数)格式 |
BINARY | 将value转换成二进制格式 |
示例
1.将值转换为DATE数据类型
-- 2017-08-29
SELECT CAST('2017-08-29' AS DATE); -- 2022-04-27 15:42:19
SELECT NOW();
-- 2022-04-27
SELECT CAST(NOW() AS DATE);
2.将值转换为DATETIME数据类型
-- 2022-04-27 00:00:00
SELECT CAST('2022-04-27' AS DATETIME);
3.将值转换为TIME数据类型
-- 14:06:10
SELECT CAST('14:06:10' AS TIME);
-- 14:06:10
SELECT CAST('2022-04-27 14:06:10' AS TIME);
4.将值转换为CHAR数据类型
-- '150'
SELECT CAST(150 AS CHAR); -- 出错Error
SELECT CONCAT('Hello World',437));
-- 'Hello World437'
SELECT CONCAT('Hello World',CAST(437 AS CHAR));
5.将值转换为SIGNED数据类型
-- 5
SELECT CAST('5.0' AS SIGNED);
-- 2
SELECT (1 + CAST('3' AS SIGNED))/2;
-- -5
SELECT CAST(5-10 AS SIGNED);
-- 6
SELECT CAST(6.4 AS SIGNED);
-- -6
SELECT CAST(-6.4 AS SIGNED);
-- 7
SELECT CAST(6.5 AS SIGNED);
-- -7
SELECT CAST(-6.5 AS SIGNED);
6.将值转换为UNSIGNED数据类型
-- 5
SELECT CAST('5.0' AS UNSIGNED);
-- 6
SELECT CAST(6.4 AS UNSIGNED);
-- 0
SELECT CAST(-6.4 AS UNSIGNED);
-- 7
SELECT CAST(6.5 AS UNSIGNED);
-- 0
SELECT CAST(-6.5 AS UNSIGNED);
7.将值转换为DECIMAL数据类型
-- 9
SELECT CAST('9.0' AS DECIMAL);-- DECIMAL(数值精度,小数点保留长度)
-- DECIMAL(10,2)可以存储最多具有8位整数和2位小数的数字
-- 精度与小数位数分别为10与2
-- 精度是总的数字位数,包括小数点左边和右边位数的总和
-- 小数位数是小数点右边的位数
-- 9.50
SELECT CAST('9.5' AS DECIMAL(10,2));
-- 99999999.99
SELECT CAST('1234567890.123' AS DECIMAL(10,2));-- 220.232
SELECT CAST('220.23211231' AS DECIMAL(10, 3));
-- 220.232
SELECT CAST(220.23211231 AS DECIMAL(10, 3));
练习案例
导入数据
DROP TABLE IF EXISTS `Material`;
CREATE TABLE `Material` (`ID` varchar(255) DEFAULT NULL,`Material` varchar(255) DEFAULT NULL,`FileName` varchar(255) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;INSERT INTO `Material` VALUES ('1', '07-100215-01', 'FD03-FCZ-220430012624541.txt');
INSERT INTO `Material` VALUES ('2', '07-100390-01', 'FD03-FCZ-210318012624541.txt');
INSERT INTO `Material` VALUES ('3', '07-1043-01', 'FD03-FCZ-170430012624541.txt');
INSERT INTO `Material` VALUES ('4', '07-1044-01', 'FD03-FCZ-191225012624541.txt');
INSERT INTO `Material` VALUES ('5', '07-1045-01', 'FD03-FCZ-200601012624541.txt');
INSERT INTO `Material` VALUES ('6', '07-1046-01', 'FD03-FCZ-180705012624541.txt');
Material表
Material:料号 FileName:文件名称(存储相应料号位置)
注明: ID,Material,FileName都是VARCHAR类型
FileName取值举例说明:'FD03-FCZ-220430012624541.txt',红色标注数字代表年月日,其余都取值相同(不用考虑具体含义)
问题:查询小于220401(整数类型年月日数值)的Material
SELECT Material
FROM (SELECT Material,(CAST(SUBSTRING(FileName,10,6)AS SIGNED))AS 'time'FROM MaterialWHERE 'time' < 220401)AS filter_material;
解题思路
利用SUBSTRING函数截取FileName值中代表年月日的数字
由于FileName中的值为varchar类型,220401为整数类型,需要使用CAST函数进行类型转换
结果展示:
[Mysql] CAST函数相关推荐
- MySQL cast()函数
转载自 MySQL cast()函数 MySQL CAST函数介绍 MySQL CAST()函数的语法如下: CAST(expression AS TYPE); CAST()函数将任何类型的值转换 ...
- MySQL / cast()函数
MySQL / cast()函数 场景:如何数字后的0去掉? SELECT IF(`repeat_indicator`=0,'临时医嘱','长期医嘱') '医嘱类型', `plan_time` '计划 ...
- MySQL CAST 函数与 CONVERT 函数
Ptw-cwl 前面我们介绍的两个函数用于字符串和日期类型之间进行相互转换,有时我们需要数据之间的转换不仅仅局限在字符串和日期之前.接下来笔者给大家介绍的 cast() 函数和 convert() 函 ...
- MySQL - cast()函数
日常建表习惯用 create tabel tb_name as select......,这种建表方式的其中一个缺点就是:系统会根据查询出的字段,定义字段类型.有时候会把 '%Y-%m-%d' 格式 ...
- MySQL CAST()函数用法
一.语法 expr:源数据,如字符串'China'. type:目标数据类型,例如CHAR. cast(expr AS type) 二.命令说明 将任何类型的值转换为具有指定类型的值. CAST()函 ...
- mysql类型转换及小数点保留问题(cast函数)
在写SQL里面总会遇到数据类型的问题,这里讲一下cast的用法: 1.类型转换 MySQL 的CAST()函数可用来获取一个类型的值,并产生另一个类型的值 cast()函数是一个转换函数,参数是一个表 ...
- Mysql常用函数之CAST函数
Mysql常用函数之CAST函数 CAST函数语法规则是:Cast(字段名 as 转换的类型 ),其中类型可以为: CHAR[(N)] 字符型 DATE 日期型 DATETIME 日期和时间型 DEC ...
- mysql cast报错_在mysql中使用cast函数报错
今天遇到在使用mysql的cast函数报错的问题,这个函数的意思是把当前的字段转成某种类型的字段,我使用cast(xxxx as int) 这种方式,但是发现报错了,查阅资料发现 参考这个百度,总结来 ...
- MYSQL中,CAST函数的使用规则以及convert对比
MYSQL中,CAST函数的使用规则 CAST函数语法规则是:Cast(字段名 as 转换的类型 ),其中类型可以为: CHAR[(N)] 字符型 DATE 日期型 DATETIME 日期和时间型 D ...
最新文章
- Django 视图和模板1.4
- IE9下iframe显示异常的处理方法
- java 连接redis_Redis 开发陷阱及避坑指南!
- oid 值 内存使用_如何使用Choerodon LDAP以及配置定时任务
- java farm tycoon_Idle Farm Tycoon
- 美好生活从撸好代码开始
- 前端学习(2692):重读vue电商网站13之使用动态编辑标签
- matlab水力学工具箱,新浪潮水工设计软件
- python hash表
- db2 linux 导入数据_实现DB2数据库迁移之导入步骤在Linux下
- Db4o 新建、查询、更新、删除操作
- Word中插入分隔线
- 数据创造价值,数据分析主要为哪几步?
- 计算机系统文件格式,iso是什么文件格式,怎么使用呢?
- exoplay切换全屏_02.视频播放器整体结构
- Linux快捷键大全
- 开发人员必备的13项技能
- 华为交换机查看本机mac地址命令
- NAND、NOR、FLASH、Memory
- loadrunner之virtual user generator的使用
热门文章
- 安卓桌面软件_安卓和苹果不同系统的手机怎么互传便签内容? - 学显
- 获奖喜讯 | 中恒科技荣获第二届“新基建杯”BIM大赛三项大奖
- 适配PyTorch FX,OneFlow让量化感知训练更简单
- chenxi的html学习笔记
- 【AIOT】1.3 课程安排介绍
- 什么耳机性价比高?五款国产高性价比蓝牙耳机
- 2020年统考计算机试题软件,2020年计算机软件水平考试综合练习及参考答案
- 国仁猫哥:微信视频号的快速迭代;狙击抖音快手的最后一张底牌。
- 应用程序是如何被执行起来的
- idea 左下角 CRLF,LF,CR的意思和区别