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辅助编程工具
相关推荐
瑶总迷弟6 小时前
使用 mis-tei 在昇腾310P上部署 bge-m3模型belong_my_offer6 小时前
认识到精通函数yurenpai(27届找实习中)7 小时前
redis_点评(21.好友关注——关注、取关功能实现;共同关注功能实现)Rick19937 小时前
索引的排序和分组爱莉希雅&&&7 小时前
zabbix快速搭建和使用JohnYan7 小时前
工作笔记 - PG分组极值清溪5497 小时前
DataEase H2 JDBC-RCE(CVE-2025-32966)复现ServBay7 小时前
不要再盲选了,PostgreSQL、MySQL与SQLite真实性能对比Trouvaille ~7 小时前
【Redis篇】Set 与 Zset:集合运算与排行榜的终极武器無限進步D7 小时前
MySQL 创建和管理表