MySQL有SIN、TAN等三角函数,但只接受弧度输入;需用RADIANS()转换度数,如SIN(RADIANS(90))=1.0,直接SIN(90)是按90弧度计算;注意浮点精度、NULL处理、索引失效及性能优化。MySQL里没有TAN和SIN函数?其实是有的,但要注意单位MySQL原生支持SIN、COS、TAN等三角函数,但它们**只接受弧度(radians)输入**,不是度数。直接传90进去算SIN(90),结果是0.8939966636005579------因为MySQL把它当成了90弧度,不是90度。要算sin(90°),得先转弧度:SIN(RADIANS(90)) → 1.0同理,TAN(RADIANS(45))才是1.0;写成TAN(45)得到的是1.6197751905438615(45弧度≈2578°)RADIANS()和DEGREES()是配套的,别只记一半为什么SIN(0)返回0但SIN(180)不等于0?这是浮点精度和单位混淆叠加的结果。你以为SIN(180)在算180°的正弦,其实MySQL在算180弧度的正弦------而180弧度 ≈ 10313°,根本不在周期整数倍上。正确写法:SIN(RADIANS(180)) → -1.2246467991473532e-16(接近0,浮点误差)如果业务需要严格等于0(比如判断象限),别直接比较= 0,改用ABS(SIN(RADIANS(x))) 注意:MySQL的PI()返回的是近似值,SIN(PI())也不等于0,而是约1.2246e-16在WHERE或ORDER BY里用TAN要小心除零和定义域TAN在π/2 + kπ处无定义,对应角度是90°、270°、450°......MySQL遇到这些输入会返回NULL,不是报错。这在过滤或排序时容易漏数据。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
weixin_444012931 小时前
Layui上传组件upload怎么监听大文件上传的百分比进度条2301_781571421 小时前
CSS如何实现按钮颜色的流光特效_利用渐变背景定位属性m0_495496411 小时前
Python Web应用负载均衡方案_结合Nginx权重设置实现高可用weixin_444012931 小时前
uni-app怎么接极光推送 uni-app消息推送App端接入【教程】夏恪1 小时前
mysql如何配置隔离级别_mysql transaction_isolation设置小新同学^O^1 小时前
简单学习--> 神经网络2501_901006471 小时前
如何用SQL统计每组的平均值同时显示原行_OVER子句dfdfadffa1 小时前
Python后端Flask如何实现短信验证码发送_调用云厂商API实现功能ppandss11 小时前
JavaWeb从0到1-DAY5-Maven