LEFT函数非SQL标准,MySQL/SQL Server支持LEFT(col,n),PostgreSQL(9.1+)和SQLite/Oracle需用substring或substr;对NULL输入返回NULL;WHERE中使用易致全表扫描,应优先用LIKE;长度超限时LEFT安全,负数长度行为因库而异。LEFT 函数在不同数据库里的写法差异LEFT 不是 SQL 标准函数,MySQL 和 SQL Server 支持 LEFT(),但 PostgreSQL、SQLite、Oracle 默认不认------它们用 substring() 或 substr()。别一写 LEFT(col, 3) 就跑,先看库型。MySQL / SQL Server:LEFT(column_name, length) 直接可用PostgreSQL:substring(column_name from 1 for length) 或 left(column_name, length)(9.1+ 才支持)SQLite:substr(column_name, 1, length)(注意:起始位置是 1,不是 0)Oracle:substr(column_name, 1, length)LEFT 返回 NULL 的常见原因LEFT() 本身不会因参数为空报错,但它对 NULL 输入直接返回 NULL。如果你发现截取结果全空,大概率不是函数写错了,而是源字段本身就是 NULL 或空字符串。检查原始数据:SELECT column_name, LENGTH(column_name) FROM table WHERE ...安全写法加 COALESCE:LEFT(COALESCE(column_name, ''), 5)注意空格干扰:左侧带空格时,LEFT(' abc', 3) 得到的是 ' a',不是预期的 'abc'LEFT 在 WHERE 条件里用多了会拖慢查询对字段用 LEFT(column, N) 做过滤,基本等于放弃索引------除非你建了函数索引(如 PostgreSQL 的 CREATE INDEX ON t ((LEFT(col, 3)))),否则每次都要全表扫描。 文心快码 文心快码(Comate)是百度推出的一款AI辅助编程工具
相关推荐
Csvn20 分钟前
Python 两大经典坑点 —— 可变默认参数 & 闭包延迟绑定曲幽1 小时前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了用户556918817533 小时前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录倔强的石头_5 小时前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测兵慌码乱17 小时前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析luckdewei20 小时前
FastAPI 资产管理系统实战:复杂 ORM 关联、Alembic 迁移与 N+1 查询优化aqi001 天前
15天学会AI应用开发(八)使用向量数据库实现RAG功能Csvn1 天前
`functools.lru_cache` —— 一行代码搞定缓存加速金銀銅鐵2 天前
[Python] 从《千字文》中随机挑选汉字