我的编程空间,编程开发者的网络收藏夹
学习永远不晚

[Mysql] CAST函数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

[Mysql] CAST函数

CAST函数用于将值从一种数据类型转换为表达式中指定的另一种数据类型

语法

CAST(value AS datatype)

AS关键字用于分隔两个参数,在AS之前的是要处理的数据,在AS之后的是要转换的数据类型 

参数说明

value: 要转换的值

datatype: 要转换成的数据类型

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-29SELECT CAST('2017-08-29' AS DATE); -- 2022-04-27 15:42:19SELECT NOW();-- 2022-04-27SELECT CAST(NOW() AS DATE);

将值转换为DATETIME数据类型

-- 2022-04-27 00:00:00SELECT CAST('2022-04-27' AS DATETIME); 

将值转换为TIME数据类型

-- 14:06:10SELECT CAST('14:06:10' AS TIME); -- 14:06:10SELECT CAST('2022-04-27 14:06:10' AS TIME); 

将值转换为CHAR数据类型

-- '150'SELECT CAST(150 AS CHAR); -- 'Hello World437'SELECT CONCAT('Hello World',CAST(437 AS CHAR));

将值转换为SIGNED数据类型

-- 5SELECT CAST('5.0' AS SIGNED);-- 2SELECT (1 + CAST('3' AS SIGNED))/2;-- -5SELECT CAST(5-10 AS SIGNED); -- 6SELECT CAST(6.4 AS SIGNED);-- -6SELECT CAST(-6.4 AS SIGNED);-- 7SELECT CAST(6.5 AS SIGNED); -- -7SELECT CAST(-6.5 AS SIGNED);

将值转换为UNSIGNED数据类型

-- 5SELECT CAST('5.0' AS UNSIGNED);-- 6SELECT CAST(6.4 AS UNSIGNED);-- 0SELECT CAST(-6.4 AS UNSIGNED);-- 7SELECT CAST(6.5 AS UNSIGNED); -- 0SELECT CAST(-6.5 AS UNSIGNED);

 7.将值转换为DECIMAL数据类型

-- 9SELECT CAST('9.0' AS DECIMAL);-- DECIMAL(数值精度,小数点保留长度)-- DECIMAL(10,2)可以存储最多具有8位整数和2位小数的数字-- 精度与小数位数分别为10与2-- 精度是总的数字位数,包括小数点左边和右边位数的总和-- 小数位数是小数点右边的位数-- 9.50SELECT CAST('9.5' AS DECIMAL(10,2));-- 99999999.99SELECT CAST('1234567890.123' AS DECIMAL(10,2));-- 220.232SELECT CAST('220.23211231' AS DECIMAL(10, 3));-- 220.232SELECT 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 MaterialFROM (SELECT Material,(CAST(SUBSTRING(FileName,10,6)AS SIGNED))AS 'time'      FROM Material      WHERE 'time' < 220401)AS filter_material;

解题思路
利用SUBSTRING函数截取FileName值中代表年月日的数字
由于FileName中的值为varchar类型,220401为整数类型,需要使用CAST函数进行类型转换 

结果展示:

来源地址:https://blog.csdn.net/Hudas/article/details/124399908

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

[Mysql] CAST函数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL CAST与CONVERT 函数的用法

MySQL 的CAST()和CONVERT()函数可用来获取一个类型的值,并产生另一个类型的值。两者具体的语法如下:CAST(value as type); CONVERT(value, type);就是CAST(xxx AS 类型), C
2022-05-19

Mysql CAST函数的具体使用

目录语法参数说明示例练习案例CAST函数用于将值从一种数据类型转换为表达式中指定的另一种数据类型语法CAST(value AS datatype)AS关键字用于分隔android两个参数,在AS之前的是要处理的数据,在AS之后的是要转
2022-08-12

SQL中的cast()函数

语法:CAST (expression AS data_type) expression:任何有效的SQServer表达式。 AS:用于分隔两个参数,在AS之前的是要处理的数据,在AS之后是要转换的数据类型。 data_type:目标系统所提供的数据类型,包括
SQL中的cast()函数
2017-11-24

MySQL中cast函数的用法是什么

在MySQL中,CAST()函数用于将一个值转换为指定的数据类型。其语法如下:CAST(expression AS data_type)其中,expression是要转换的值,data_type是要转换为的数据类型。例如,将一个字符串转换
MySQL中cast函数的用法是什么
2024-04-09

MySQL基础教程11 —— 函数之Cast函数和操作符

BINARYBINARY操作符将后面的字符串抛给一个二进制字符串。这是一种简单的方式来促使逐字节而不是逐字符的进行列比较。这使得比较区分大小写,即使该列不被定义为 BINARY或 BLOB。BINARY也会产生结尾空白,从而更加显眼。 my
2022-05-27

oracle中cast函数用法

cast 函数用于将值显式转换为另一个数据类型,语法为 cast(expression as data_type)。用法示例包括:将数值转换为字符串、字符串转换为日期和字符串转换为数字。转换选项包括数值类型、字符类型、日期类型和布尔类型。O
oracle中cast函数用法
2024-04-30

MySQL中cast函数的应用场景有哪些

类型转换:cast函数用于将一个数据类型转换为另一个数据类型。例如,将一个字符串转换为整数、将一个浮点数转换为整数等。数据格式化:cast函数可以用于格式化日期、时间或数字等数据类型。例如,将日期格式化为特定的格式、将数字格式化为特定的精度
MySQL中cast函数的应用场景有哪些
2024-04-09

sql cast函数的作用是什么

SQL的CAST函数用于将一个表达式或列的数据类型转换为另一个数据类型。它可以在查询中用于处理不同数据类型之间的转换。CAST函数可以将数字转换为字符串,日期转换为字符串,字符串转换为数字等等。语法:CAST(expression AS
sql cast函数的作用是什么
2024-04-09

sql cast函数的用法是什么

SQL CAST函数用于将一个数据类型的值转换为另一个数据类型。它可以在SELECT语句中用于将列的数据类型转换为其他数据类型,也可以在INSERT、UPDATE和DELETE语句中用于将常量或表达式的数据类型转换为其他数据类型。CAST
sql cast函数的用法是什么
2024-04-09

MySQL 字符串转in/double类型—CAST/CONVERT函数的用法

在MySQL中,可以使用CAST和CONVERT函数将一个字符串转换为IN或DOUBLE类型。1. 使用CAST函数将字符串转换为INT类型:```sqlSELECT CAST('10' AS INT);```这将返回整型值10。2. 使用
2023-09-12

关于SQL的cast()函数解析

注意:本文使用数据库为:mysql5.6解析: CAST函数用于将某种数据类型的表达式显式转换为另一种数据类型。CAST()函数的参数是一个表达式,它包括用AS关键字分隔的源值和目标数据类型。语法:CAST (expression
2023-04-28

Sql中CAST函数怎么使用

在SQL中,CAST函数用于将一个数据类型转换为另一个数据类型。其语法如下:CAST(expression AS data_type)其中,expression是想要进行转换的表达式或列名,data_type是想要将expression
2023-10-26

sqlserver中cast函数的作用是什么

在SQL Server中,CAST函数用于将一个数据类型转换为另一个数据类型。例如,如果您有一个字符串类型的列,但希望将其转换为整数类型,则可以使用CAST函数来实现这一转换。CAST函数提供了灵活性,使您能够在不同数据类型之间进行转换,以
sqlserver中cast函数的作用是什么
2024-03-05

SQL中cast函数的作用是什么

cast函数用于将一个数据类型转换为另一个数据类型。它可以用来将一个列或值转换为不同的数据类型,例如将一个字符串转换为整数,或将一个日期转换为字符串。通过使用cast函数,可以确保数据在进行计算或比较时具有正确的数据类型,从而避免出现错误或
SQL中cast函数的作用是什么
2024-04-09

编程热搜

目录