【MySQL】CAST()在MySQL中的用法以及其他常用的数据类型转换函数
1. cast()
CAST() 在 MySQL 中用于将一个表达式的类型转换为另一个类型。这在处理不同类型的数据时非常有用,比如将字符串转换为数字,或者将浮点数转换为整数等。
1.1 CAST() 函数的基本语法
CAST() 函数的基本语法如下:
CAST(expression AS type)
expression:要转换的原始表达式。type:目标类型,可以是 BINARY、CHAR、DATE、SIGNED、UNSIGNED、FLOAT、DOUBLE、DECIMAL 等。
1.2 常用类型和格式:
BINARY:二进制格式。CHAR:字符串格式。DATE:日期格式。TIME:时间格式。DATETIME:日期时间格式。SIGNED:有符号整数。UNSIGNED:无符号整数。FLOAT:浮点数。DOUBLE:双精度浮点数。DECIMAL:小数。
1.3 示例
-
将字符串转换为整数:
SELECT CAST('123' AS SIGNED) AS integer_column;结果将是:
integer_column: 123 -
将整数转换为字符串:
SELECT CAST(123 AS CHAR) AS string_column;结果将是:
string_column: '123' -
将浮点数转换为整数:
SELECT CAST(123.456 AS SIGNED) AS integer_column;结果将是:
integer_column: 123 -
将字符串转换为日期:
SELECT CAST('2024-05-29' AS DATE) AS date_column;结果将是:
date_column: 2024-05-29 -
将日期转换为字符串:
SELECT CAST('2024-05-29' AS CHAR) AS string_column;结果将是:
string_column: '2024-05-29' -
将浮点数转换为小数:
SELECT CAST(123.456 AS DECIMAL(10, 2)) AS decimal_column;结果将是:
decimal_column: 123.46这里的
DECIMAL(10, 2)指定了小数点前的位数为 10,小数点后的位数为 2。 -
将二进制字符串转换为整数:
SELECT CAST(BINARY '11001' AS UNSIGNED) AS integer_column;结果将是:
integer_column: 25
CAST() 函数在数据处理和转换中非常有用,尤其是在数据导入和报告生成时,可以确保数据类型的正确性和一致性。
2. 其他常用的数据类型转换函数
在 MySQL 中,除了 CAST() 函数,还有几个其他函数也常用于数据类型转换:
-
CONVERT(): 与CAST()类似,但语法略有不同,并且可以用于转换为不同的数据类型。CONVERT(expression, type)或者
CONVERT(type, expression)CONVERT()可以用于将字符串转换为日期时间,或者在转换时指定不同的字符集。 -
BIN(): 将整数转换为二进制字符串。BIN(number) -
HEX(): 将整数转换为十六进制字符串。HEX(string_or_number) -
OCT(): 将整数转换为八进制字符串。OCT(number) -
ELT(): 根据索引值返回字符串数组中的一个值,常用于条件转换。ELT(index, str1, str2, ...) -
FIELD(): 与ELT()类似,但可以处理多个参数,返回第一个匹配值的字符串。FIELD(str, str1, str2, ...) -
INET_ATON(): 将点分十进制的 IP 地址转换为无符号整数。INET_ATON(string) -
INET_NTOA(): 将无符号整数转换为点分十进制的 IP 地址。INET_NTOA(inet_address) -
RAND(): 返回一个随机浮点数。RAND([number]) -
SIGN(): 返回参数的符号,-1 表示负数,0 表示零,1 表示正数。SIGN(number)
-
ASCII(): 返回字符串的第一个字符的 ASCII 值。ASCII(string)
-
CHAR_LENGTH()或LENGTH(): 返回字符串的长度。CHAR_LENGTH(string)
-
CHARACTER_LENGTH(): 与CHAR_LENGTH()类似,返回字符串的长度。CHARACTER_LENGTH(string)
-
LOWER(): 将字符串转换为小写。LOWER(string)
-
UPPER(): 将字符串转换为大写。UPPER(string)
-
LTRIM(): 去除字符串左侧的空格。LTRIM(string)
-
RTRIM(): 去除字符串右侧的空格。RTLRIM(string)
-
TRIM(): 去除字符串两侧的空格。TRIM([str,] string)
-
DATE_FORMAT(): 将日期时间格式化为字符串。DATE_FORMAT(date, format)
-
TIME_FORMAT(): 将时间格式化为字符串。TIME_FORMAT(time, format)
这些函数可以在不同的场景下使用,以实现数据类型的转换和处理。
相关文章:
【MySQL】CAST()在MySQL中的用法以及其他常用的数据类型转换函数
1. cast() CAST() 在 MySQL 中用于将一个表达式的类型转换为另一个类型。这在处理不同类型的数据时非常有用,比如将字符串转换为数字,或者将浮点数转换为整数等。 1.1 CAST() 函数的基本语法 CAST() 函数的基本语法如下: CAST(expression…...
使用Truffle、Ganache、MetaMask、Vue+Web3完成的一个简单区块链项目
文章目录 概要初始化Truffle项目创建编写合约编译合约配置Ganache修改truffle-config.js文件编写迁移文件部署合约使用Truffle 控制台使用MetaMask和VueWeb3与链交互 概要 使用Truffle、Ganache、MetaMask、VueWeb3完成的一个简单区块链项目。 初始化Truffle项目 安装好truf…...
初出茅庐的小李博客之按键驱动库使用
驱动库介绍 源码地址:https://github.com/jiejieTop/ButtonDrive 使用只需3步,创建按键,按键事件与回调处理函数链接映射,周期检查按键,支持单双击、连按、长按;采用回调处理按键事件(自定义消…...
如何调试Linux内核?
通过创建一个最小的根文件系统,并使用QEMU和GDB进行调试。 1.准备工作环境 确保系统上安装了所有必要的工具和依赖项。 sudo apt-get update //更新一下软件包 sudo apt-get install build-essential git libncurses-dev bison flex libssl-dev qemu-system-x…...
ECharts组件封装教程:Vue3中的实践与探索
在日常的前端开发中,ECharts 作为一款强大且易用的图表库,被广泛应用于数据可视化场景。为了更好地在 Vue3 项目中复用 ECharts 功能,我们可以将其封装成一个组件。本文将带大家一步步实现 ECharts 的 Vue3 组件封装,并演示如何在父组件中调用和使用。 一、封装 ECharts 组…...
NAT 代理服务 内网穿透
🌈 个人主页:Zfox_ 🔥 系列专栏:Linux 目录 一:🔥 NAT 技术背景二:🔥 NAT IP 转换过程三:🔥 NAPT四:🔥 代理服务器🦋 正向…...
CAN硬件协议详解
一、基本理论: 1、CAN的总线结构: CAN总线 网络结构 有 闭环和开环 两种形式;无论实际的网络多复杂,都离不开这两种基本结构。 闭环结构的CAN总线网络,总线的两端各并联一个120Ω的电阻,两…...
网络安全等级保护:网络安全等级保护基本技术
下面我们概括性探讨一下等级保护用到的一些技术,有关这些技术的每一个方面的每一个部分都可以是一部大块头,甚至一部大块头都无法介绍清楚,需要系列性的书籍去展开,所以这里也只能做到抛砖而已。期望起到抛砖引玉的作用࿰…...
信刻光盘安全隔离与信息交换系统让“数据摆渡”安全高效
随着数据传输、存储及信息技术的飞速发展,信息安全保护已成为重中之重。各安全领域对跨网数据交互的需求日益迫切,数据传输的安全可靠性成为不可忽视的关键。为满足业务需求并遵守保密规范,针对于涉及重要秘密信息,需做到安全的物…...
数据结构课程设计(java实现)---九宫格游戏,也称幻方
【问题描述】 九宫格,一款数字游戏,起源于河图洛书,与洛书是中国古代流传下来的两幅神秘图案,历来被认为是河洛文化的滥觞,中华文明的源头,被誉为"宇宙魔方"。九宫格游戏对人们的思维锻炼有着极大…...
[思考记录]AI时代下,悄然的改变
尝试用 xAI-Grok 去了解DS开源周的信息,有那么点被Grok的输出惊艳到。“请你以技术编辑的角色,重点参考官方文档,介绍DeepSeek开源周的内容,写一篇技术分享文章。”,得到的文字看起来很是舒服,内容靠谱、结…...
JAVA笔记【一】
现实 (抽象) 类 (创建) 对象 特点: 1.面向对象 2.跨平台 3.安全性 4.多线程 java程序基本结构 1. java源代码文件实际是普通的文本文件,源代码文件必须是.java扩展名,且必须小写 2. …...
[Java基础] 常用注解
文章目录 1. 元注解2. 非元注解2.1 常用JDK自带注解2.2 常用Spring相关注解2.2.1 在Spring框架中,注解用于简化配置和增强代码的可读性。以下是常用的Spring注解的一部分2.2.2 针对controller的相关注解2.2.3 AOP相关注解2.2.4 Enable系列注解 2.3 常用Lombok注解 1…...
uvm中的run_test作用
在SystemVerilog和UVM验证环境中,run_test() 是启动UVM仿真流程的核心函数。它负责初始化UVM框架、创建测试用例实例,并触发UVM的Phase机制来执行验证环境的构建和运行 1. run_test() 的作用 run_test() 是UVM提供的内置函数,定义在UVM库中…...
brew search报错,xcrun:error:invalid active developer path CommandLineTools
问题出现的原因 出现“xcrun: error: invalid active developer path (/Library/Developer/CommandLineTools), missing xcrun at: /Library/Developer/CommandLineTools/usr/bin/xcrun”错误,通常是因为Xcode命令行工具未正确安装或其路径已损坏。以下是几种常见的…...
C#内置委托(Action)(Func)
概述 在 C# 中,委托是一种类型,它表示对具有特定参数列表和返回类型的方法的引用。C# 提供了一些内置委托,使得开发者可以更方便地使用委托功能,无需手动定义委托类型。本文将详细介绍 Action 和 Func 这两个常用的内置委托。 A…...
kubernetes 部署项目
随着容器化技术的发展,使用Kubernetes(简称K8s)来部署和管理应用已经成为现代软件开发的标准实践之一。Kubernetes提供了一套强大的工具集,使得部署、扩展和管理应用程序变得更为简便高效。本文将带你走过从准备环境到部署一个实际…...
《几何原本》命题I.2
《几何原本》命题I.2 从一个给定的点可以引一条线段等于已知的线段。 设 A A A 为给定点, B C BC BC 为给定线段 连接 A B AB AB,作等边 △ A B D \triangle ABD △ABD 以 B B B 为圆心, B C BC BC 为半径作小圆 延长 D B DB DB 交小圆…...
【我的 PWN 学习手札】House of Kiwi
House of Kiwi 之前我们利用IO_FILE一般是通过劫持vtable来实现的, House of Kiwi虽然不是通过劫持vtable来实现,但实质上是劫持vtable指向的全局的_IO_file_jumps_表来实现的。注意:对于某些版本的glibc,_IO_file_jumps_并不可写…...
nvm的学习
学习 nvm(Node Version Manager) 是掌握 Node.js 开发的关键技能之一。以下是系统的学习路径和实战指南,涵盖从基础到进阶的内容: 一、基础入门 1. nvm 的核心作用 多版本共存:安装和管理多个 Node.js 版本ÿ…...
别再死记硬背DH参数表了!用Python从零推导PUMA560机器人正运动学(附完整代码)
用Python实战解析PUMA560机器人运动学:从DH参数到三维可视化 在机器人学领域,正运动学分析是理解机械臂运动原理的基础。许多初学者面对抽象的Denavit-Hartenberg(DH)参数和复杂的坐标系变换时,常常陷入死记硬背的困境…...
5分钟掌握Scala.js构建工具链:从开发到生产的完整指南
5分钟掌握Scala.js构建工具链:从开发到生产的完整指南 【免费下载链接】scala-js Scala.js, the Scala to JavaScript compiler 项目地址: https://gitcode.com/gh_mirrors/sc/scala-js Scala.js是一个功能强大的Scala到JavaScript编译器,它允许开…...
Webpack Tree Shaking配置终极指南:如何在Awesome-Webpack中优化现代前端项目
Webpack Tree Shaking配置终极指南:如何在Awesome-Webpack中优化现代前端项目 【免费下载链接】awesome-webpack A curated list of awesome Webpack resources, libraries and tools 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-webpack Webpack …...
逻辑器件设计中的总线保持(Bus Hold)功能解析与实战案例
1. 总线保持功能的前世今生 第一次听说总线保持(Bus Hold)这个概念,还是在五年前的一个深夜。当时我负责的项目遇到一个诡异现象:设备在热插拔时,主控板经常无法检测到业务板的拔出动作。排查了整整三天,最…...
Linux文件系统探秘:当你删除一个文件时,inode位图究竟发生了什么变化?
Linux文件系统探秘:当你删除一个文件时,inode位图究竟发生了什么变化? 在Linux系统中,删除文件看似是一个简单的操作,但背后却隐藏着一系列精密的元数据操作。对于系统开发者和运维人员而言,理解这一过程不…...
无线工程师必备:用Wireshark解码802.11ac VHT Capabilities字段全攻略(含160MHz配置示例)
无线网络深度解析:802.11ac VHT Capabilities字段实战指南 在当代企业级无线网络部署中,802.11ac协议已成为高吞吐量应用的核心支撑。作为无线工程师,能否精准解读VHT(Very High Throughput)Capabilities信息元素&…...
号令天下:守财数字能量号组413与313能守财吗
在数字能量学的体系中,延年磁场是主导守财的核心能量,天医磁场主打招财纳福,生气磁场侧重拓展人脉,二者并不具备直接的守财属性。像 413、313 这类组合,核心作用集中在招财聚财方面,守财能力相对薄弱&#…...
OpenClaw自动化周报:Qwen3.5-9B-AWQ-4bit整合截图生成工作总结
OpenClaw自动化周报:Qwen3.5-9B-AWQ-4bit整合截图生成工作总结 1. 为什么需要自动化周报 每周五下午,我的电脑屏幕总会同时开着十几个窗口:项目管理系统截图、代码提交记录、会议纪要文档、临时笔记文件……把这些碎片信息整理成结构化周报…...
他没有打断我,没有说“小孩子懂什么” ,30岁这年,我不仅拿到了父亲的认可,更拿到了他毫无保留的信任
30岁这年,我和我爸 今天和我爸坐在阳台的小茶桌前,泡了他藏了快十年的普洱,烟缸里攒了四根烟蒂,聊了整整两个小时。 散场的时候我站在窗边看他下楼开车,突然反应过来——我们今天这场对话,从头到尾没有一句“你要听话”,没有一句“钱够不够花”,没有长辈居高临下的说…...
2026届必备的十大降重复率工具实际效果
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 当前,人工智能生成内容于各类文本里的广泛运用引发了对于原创性以及真实性的关注…...
