SQL中如何获取所有列的数据:SELECT -星号用法与性能影响

能用但多数时候不该用------它会解析全部列元数据、传输冗余字段、阻碍执行计划优化,易引发列名冲突、ORM映射错乱等问题,仅限调试或结构极小稳定时使用。SELECT * 在真实查询中到底能不能用能用,但多数时候不该用------不是语法错误,而是隐性成本太高。它会让数据库多做三件事:解析全部列元数据、传输冗余字段、让执行计划更难优化。常见错误现象:SELECT * 在视图或 JOIN 后返回重复列名(比如两个表都有 id),导致应用层取值混乱;ORM 自动映射时字段顺序错位,甚至静默丢数据。只在临时查数、调试、或明确知道表结构极小且稳定时用(比如 users 表只有 4 列且半年不加字段)生产接口、报表 SQL、ETL 脚本里一律显式写列名,哪怕多敲几下如果真要"所有列",先用 SELECT column_name FROM information_schema.columns WHERE table_name = 'xxx' 拉出来再拼,而不是靠星号偷懒MySQL 和 PostgreSQL 对 SELECT * 的处理差异表面一样,底层行为不同:MySQL 在准备阶段就展开 * 成具体列,而 PostgreSQL 把它留到执行期才解析,这对视图和权限控制影响明显。使用场景举例:你在 PostgreSQL 里给用户授予 SELECT 权限到某视图,但该视图定义含 SELECT *,一旦基表加了新列,用户立刻能查到------这常被当成权限绕过漏洞。MySQL 中 * 展开后,如果后续 ALTER TABLE ADD COLUMN,旧的预编译语句不会自动包含新列PostgreSQL 中 * 是"活"的,视图或函数里用它等于每次重查系统表,性能略差但语义更直观两者都不支持对 * 做别名(SELECT * AS data FROM t 是语法错误)SELECT * 和 COUNT(*) 性能完全不是一回事这是最常被混淆的点:COUNT(*) 是统计行数,优化器知道可以走索引或元数据,基本不读数据页;而 SELECT * 必须把每行所有字段从磁盘或缓冲区捞出来,IO 和网络开销指数级增长。 VWO 一个A/B测试工具

相关推荐
m0_515098421 小时前
如何增加RAC节点_addnode.sh脚本执行与实例扩展全流程
jvm·数据库·python
qq_654366981 小时前
生产环境mysql如何实现高可用_配置主从复制与自动故障切换
jvm·数据库·python
jason_renyu1 小时前
图书馆管理系统完整开发文档(Flask + Vue3 + Element Plus + MySQL )
python·python学习·flask毕业设计例子·flask学习例子·flask入门
费弗里1 小时前
新版本Dash完美支持原生FastAPI后端
python·fastapi·dash
Ulyanov2 小时前
《玩转QT Designer Studio:从设计到实战》 QT Designer Studio环境搭建与核心工作区详解
开发语言·python·qt·系统仿真·雷达电子战系统仿真
2301_816660212 小时前
c++ openimageio工具 c++如何使用oiiotool进行图像批量处理
jvm·数据库·python
Kristrina2 小时前
MySQL大小写敏感、MySQL设置字段大小写敏感
数据库·mysql
Teable任意门互动2 小时前
多维表格本地化部署实践解析,企业如何实现数据自主可控路径
数据库·低代码·信息可视化·开源·数据库开发
曼岛_2 小时前
[逆向工程]160个CrackMe入门实战之Andrnalin.2解析(九)
java·数据库·microsoft·逆向