SQL中字段算术运算直接用+?×÷,无需函数;需注意空格、括号优先级、类型一致性、NULL传播、显式别名、数据库差异及WHERE/ORDER BY中不可用别名。SELECT 中直接用算术运算符做字段计算SQL 里对字段做加减乘除,不需要额外函数,直接在 SELECT 后写表达式就行。比如查商品售价打 9 折后的价格,写成 price * 0.9 就能出结果。常见错误是漏掉空格或括号导致优先级混乱,比如 price + 10 * 0.9 实际算的是 price + 9,不是 (price + 10) * 0.9。数值类型不一致也会隐式转换失败------MySQL 可能容忍,PostgreSQL 遇到 text 字段参与 + 运算会直接报错 operator does not exist: text + integer。整数除法要注意:SQLite 和 PostgreSQL 默认返回整数(5 / 2 → 2),想得小数得先转 CAST(5 AS REAL) / 2 或写成 5.0 / 2NULL 参与任何算术运算结果都是 NULL,别指望它当 0 处理;真要兜底,得显式用 COALESCE(price, 0) * 0.9字符串字段误当数字用很常见,比如把 status(值为 'active')写进 + 1,MySQL 会悄悄转成 0 再加,PostgreSQL 直接拒了用 AS 给计算结果起别名,避免列名丢失算术表达式默认没有列名,查询结果里那列可能显示成 ?column?(PostgreSQL)、expr(SQLite)或者干脆空着。必须用 AS 显式命名,否则下游代码取不到字段,导出 CSV 时列头也糊里糊涂。别名本身不参与计算,只是输出标签,所以不能在 WHERE 里引用------比如 SELECT price * 0.9 AS discounted_price WHERE discounted_price > 100 会报错,得写成 WHERE price * 0.9 > 100 或者套一层子查询。AS 关键字可省略,price * 0.9 discounted_price 也能用,但加 AS 更清晰,尤其在团队协作或复杂查询里别名里有空格或特殊字符(如连字符)必须用双引号括起来:price * 0.9 AS "discounted-price",否则语法错误别名不能和表里已有字段同名且没加表前缀,否则 ORDER BY 时可能歧义------数据库优先认原始字段名不同数据库对运算符和类型转换的容忍度差异同一个表达式,在 MySQL、PostgreSQL、SQLite 甚至 SQL Server 上行为可能完全不同。核心分歧点在「宽松转换」还是「严格类型检查」。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
2401_827499992 小时前
python项目实战11-正则表达式基础小糖学代码2 小时前
LLM系列:1.python入门:6.元组型对象(tuple)ZC跨境爬虫2 小时前
Scrapy实战:5sing原创音乐网多页数据爬取(完整可运行,附避坑指南)那个失眠的夜2 小时前
Spring 的纯注解配置XDHCOM2 小时前
ORA-06722: TLI Driver连接失败,Oracle报错修复对比远程处理,选择最佳解决方案西西弗Sisyphus2 小时前
Python dataclasses 中 field 的 default_factory 参数用法小红的布丁2 小时前
Redis 集群详解:主从哨兵和切片集群有什么区别杰克尼2 小时前
redis(day08-Redis原理篇)余佬学数据库2 小时前
Oracle 19c RECOVER TABLE 恢复误删除数据