当前位置: 首页 > news >正文

视图 vs 直接使用复杂SQL:深入比较

1. 集中管理,一处修改多处受益

  • 问题场景:当同一个复杂SQL在10个地方使用时,如果基础表结构变化,你需要修改所有10处SQL

  • 视图解决方案:只需修改视图定义,所有使用该视图的地方自动获得更新

  • 实际案例:当users表拆分为user_profilesuser_credentials时,只需调整视图,应用代码无需改动

2. 权限控制的粒度差异

  • 直接SQL的限制:你只能控制用户对基表的访问权限(全部或全不)

  • 视图的优势:可以做到:

    GRANT SELECT ON customer_orders_view TO sales_team;
    REVOKE SELECT ON orders FROM sales_team; -- 他们不能直接访问基表
  • 安全场景:财务部门能看到完整订单视图,而客服部门只能看到订单基本信息和客户联系方式视图

3. SQL注入防护的额外层级

  • 直接SQL风险:应用层拼接SQL容易产生注入漏洞

  • 视图防护:可以创建"白名单"视图限制可访问数据范围,即使发生注入,攻击者也只能看到视图限定范围内的数据

4. 数据库优化器的特殊处理

  • 视图优化:现代数据库会对视图查询进行特殊优化,例如:

    • 视图合并(View Merging):将视图SQL合并到主查询进行整体优化

    • 谓词下推(Predicate Pushdown):将WHERE条件推送到视图内部

  • 执行计划优势:有时通过视图访问比直接写复杂SQL能获得更好的执行计划

5. 跨平台兼容性层

  • 迁移场景:当从MySQL迁移到Oracle时,可以通过调整视图定义保持应用层SQL不变

  • 分库分表:在分表情况下,视图可以隐藏分表细节,对应用呈现统一接口

6. 物化视图的特殊价值

  • 性能关键:物化视图实际存储计算结果,对聚合查询可提升数百倍性能

  • 自动刷新:支持定时或增量刷新,如Oracle的REFRESH FAST ON COMMIT

实际开发中的平衡建议

  1. 简单查询:直接写在应用层确实更合适

  2. 复用超过3次的复杂查询:考虑创建视图

  3. 涉及权限控制:优先使用视图

  4. 报表类查询:视图是更好的选择

  5. 高频复杂查询:考虑物化视图

典型示例对比

直接SQL方式

# 应用代码中
def get_orders(user_id):sql = """SELECT o.id, o.date, p.name, p.price, SUM(oi.quantity) as total_quantity,u.name as customer_nameFROM orders oJOIN order_items oi ON o.id = oi.order_idJOIN products p ON oi.product_id = p.idJOIN users u ON o.user_id = u.idWHERE o.user_id = %sGROUP BY o.id, o.date, p.name, p.price, u.name"""# 执行查询...

视图方式

-- 数据库层
CREATE VIEW user_order_details AS
SELECT o.id, o.date, p.name, p.price, SUM(oi.quantity) as total_quantity,u.name as customer_name
FROM orders o
JOIN order_items oi ON o.id = oi.order_id
JOIN products p ON oi.product_id = p.id
JOIN users u ON o.user_id = u.id
GROUP BY o.id, o.date, p.name, p.price, u.name;-- 应用代码
def get_orders(user_id):sql = "SELECT * FROM user_order_details WHERE user_id = %s"# 执行查询...

当需要添加"折扣计算"逻辑时,视图方案只需在数据库修改一次,而直接SQL方案需要修改所有相关查询。

http://www.dtcms.com/a/317219.html

相关文章:

  • 场外期权的卖方是什么策略?
  • 未给任务“Fody.WeavingTask”的必需参数“IntermediateDir”赋值。 WpfTreeView
  • WPF的C1FlexGrid的单元格回车换行输入
  • 自学嵌入式 day45 ARM体系架构
  • Android Studio 利用工具检查未被使用的字符串
  • 排序算法(二)
  • vasp计算弹性常数
  • GISBox中OSGB数据转3DTiles格式指南
  • DDoS防护中的流量清洗与智能调度:构建网络安全坚实屏障
  • 《动手学深度学习》读书笔记—9.6编码器-解码器架构
  • 秋招笔记-8.6
  • Hive【应用 04】常用DDL操作(数据库操作+创建表+修改表+清空删除表+其他命令)
  • Win7 RTM和SP1的区别
  • 系统运维之PXE原理篇
  • 【软考系统架构设计师备考笔记5】 - 专业英语
  • 手机充电器质量体系模板
  • Rust进阶-part5-trait
  • 深入理解SpringMVC DispatcherServlet源码及全流程原理
  • PHP-Casbin:现代化 PHP 应用的权限管理引擎
  • 小程序中,给一段富文本字符串文案特殊内容加样式监听点击事件
  • 移动商城平台适配:ZKmall开源商城鸿蒙 / 小程序端开发要点
  • 盲盒抽卡机小程序系统开发:打造个性化娱乐新平台
  • 用html写一个类似于postman可以发送请求
  • 8.6 JavaWeb(请求响应 P67-P74)
  • 生成模型实战 | GPT-2(Generative Pretrained Transformer 2)详解与实现
  • 医疗AI中GPU部署的“非对等全节点架构“方案分析(中)
  • 企业级MCP部署实战:从开发到生产的完整DevOps流程
  • 【C++】unordered系列容器使用及封装
  • 高温环境误检率↓76%!陌讯轻量化检测算法在短袖短裤识别的工业实践
  • Mac 洪泛攻击笔记总结补充