0

0

mysql怎么进行类型转换

青灯夜游

青灯夜游

发布时间:2022-01-05 14:59:00

|

22918人浏览过

|

来源于php中文网

原创

转换方法:1、用“+”运算符,语法“SELECT 1+'字符串';”;2、用CAST()函数,可将任意类型转为指定类型,语法“CAST(expr AS type)”;3、用DATE_FORMAT()函数,可将日期按照给定的模式转换成字符串。

mysql怎么进行类型转换

本教程操作环境:windows7系统、mysql8版本、Dell G3电脑。

1、隐式类型转换和显式类型转换的概念

隐式类型装换:

两个值进行运算或者比较,首先要求数据类型必须一致。如果发现两个数据类型不一致时就会发生隐式类型转换。例如,把字符串转成数字,或者相反:

SELECT 1+'1'; – 字符串1转成数字
SELECT concat(2,'test'); – 数字2转成字符串

显式类型转换:

利用函数进行数据类型的转换

2.Cast函数

CAST(expr AS type)

将任意类型的表达式expr转换成指定类型type的值。type可以是以下任意类型之一:

  • BINARY[(N)] :二进制字符串,转换后长度小于N个字节( 不足长度N则尾部补上0x00 )

  • CHAR[(N)] :字符串,转换后长度小于N个字符

  • DATE :日期

  • DATETIME :日期时间

  • DECIMAL[(M[,N])] :浮点数,M为数字总位数(包括整数部分和小数部分),N为小数点后的位数

  • SIGNED [INTEGER] :有符号整数

  • TIME :时间

  • UNSIGNED [INTEGER] :无符号整数

字符串转成数字

转成decimal时,从头扫描字符串直到第一个不为数字的字符为至。对截断的那一位进行四舍五入

1)默认不限定M,N,转换为整数,按照小数点后第一位进行四舍五入:

SELECT cast(‘28.82abc’ AS DECIMAL);

在这里插入图片描述

2)限定M不限定N,转换为整数(M尽量大一些):

SELECT cast(‘28.82abc’ AS DECIMAL(4));

在这里插入图片描述

如果M的长度小于实际的数字位数时,会转换成设定位数的最大值。下面这个转换中M为1,即显示不了29这个两位数,就会显示1位数中最大的9

SELECT cast(‘28.82abc’ AS DECIMAL(1));

在这里插入图片描述

M、N都限定,必须先满足小数点后的N位小数。下例中,先满足了1位小数,再取1位整数:

SELECT cast(‘28.82abc’ AS DECIMAL(2,1));

在这里插入图片描述

先满足2位小数,不取整数部分:

SELECT cast(‘28.82abc’ AS DECIMAL(2,2));

在这里插入图片描述

SELECT cast(‘28.82abc’ AS UNSIGNED);

在这里插入图片描述

SELECT cast(’-28abc’ AS SIGNED);

在这里插入图片描述

字符串到日期

SELECT cast(‘2007-12-25’ AS DATETIME);

在这里插入图片描述

SELECT cast(‘2007-12-25’ AS DATE);

在这里插入图片描述

SELECT cast(‘20:20:20’ AS TIME);

在这里插入图片描述

日期格式必须是‘YYYY-MM-DD’

SELECT cast(‘25-12-2007’ AS DATETIME);
SELECT cast(‘2007-may-25’ AS DATETIME);

在这里插入图片描述
在这里插入图片描述

数字到字符串

X Detector
X Detector

最值得信赖的多语言 AI 内容检测器

下载
SELECT cast(123 AS CHAR);
 SELECT cast(123 AS BINARY);

日期到字符串

SELECT cast(now() AS CHAR);

在这里插入图片描述

字符串到二进制字符串(binary string)

二进制字符串:二进制字符串被视为一个连续的字节序列,与字符集无关。非二进制字符串(即我们通常所说的字符串)被视为一个连续排列的字符序列,与字符集有关。所谓与字符集无关,是指与MySQL自己的字符集无关,而是按照操作系统的字符集把字符串转换成字节进行存储

两种字符串的比较方式:二进制字符串的比较方式是一个字节一个字节进行的,比较的依据是两个字节的二进制值。因为同一个字母的大小写的数值编码是不一样的,因此它是区分大小写的。另外,由于它和字符集无关,因此也就没有大写和小写字母一说

非二进制字符串的比较方式是一个字符一个字符进行的,比较的依据是两个字符在字符集中的先后顺序。根据使用的校对不同,可以进行区分大小写的比较和不区分大小写的比较

使用CAST(str AS BINARY)将字符串转换成二进制字符串时,通常使用它的快捷方式写法: BINARY str

查看当前字符集和校对规则设置

SHOW VARIABLES LIKE ‘collation_%’;

在这里插入图片描述

在比较表达式中,binary影响后面所有的字符串,并且不会忽略字符串的尾部空格

SELECT ‘a’ = ‘A’ ,BINARY ‘a’ = ‘A’;
 SELECT ‘a’ = 'a ',BINARY ‘a’ = 'a ';

在这里插入图片描述

在这里插入图片描述

Cast(col_name as date_type)

将指定的列或者表达式转换为指定的数据类型

使用场景:当两个值进行比较,但是数据源的表中列的数据不一致,这个时候可以使用cast函数进行转化

3.Convert函数

CONVERT(expr, type), CONVERT(expr USING sharset_name)

convert函数的作用和cast函数几乎相同,但是它可以把字符串从一种字符集转换成另一种字符集。下例将字符串’abc’从默认的字符集转换成utf8字符集

SELECT convert(‘abc’ USING utf8);

在这里插入图片描述

SELECT convert(‘你好’ USING gbk);

在这里插入图片描述

如果目标字符集不能表示该字符,则返回乱码

SELECT convert(‘你好’ USING latin1);

在这里插入图片描述

日期字符串转换函数

DATE_FORMAT(date, format)

将日期date按照给定的模式format转换成字符串。format中可使用以下模式元素
在这里插入图片描述

在这里插入图片描述

SELECT date_format(‘2009-10-04 22:23:00’, ‘%W %M %Y’);

在这里插入图片描述

SELECT date_format(now(), ‘%W %M %Y’);

在这里插入图片描述

SELECT date_format(‘2007-10-04 22:23:00’, ‘%H:%i:%s’);

在这里插入图片描述

TIME_FORMAT(date, format)

format中只可使用时、分、秒和微秒模式元素

SELECT time_format(‘22:23:01’, ‘%H.%i.%s’);

在这里插入图片描述

STR_TO_DATE(str, format)

将字符串str以指定的模式format转换成日期。format中可以包含模式元素和字面量,字面量必须匹配str中的字面量:

SELECT str_to_date(‘01,5,2013’,’%d,%m,%Y’);
SELECT str_to_date(‘May 1, 2013’,’%M %d,%Y’);

在这里插入图片描述
以下在会话变量@@sql_mode设置中包含no_zero_date和no_zero_in_date时转换失败,没有包含这些设置时转换成功

SELECT str_to_date(‘a09:30:17’,‘a%h:%i:%s’);
 SELECT str_to_date(‘09:30:17a’,’%h:%i:%s’);

在这里插入图片描述在这里插入图片描述

【相关推荐:mysql视频教程

相关专题

更多
Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

37

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

37

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

交互式图表和动态图表教程汇总
交互式图表和动态图表教程汇总

本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

9

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 793人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号