前路漫漫兮 2018-06-12 01:48 采纳率: 33.3%
浏览 1195
已采纳

sqlserver中表值函数的常用方法技巧有哪些?

因ERP框架限制,很多地方必须使用表值函数,不能使用存储过程,同时查询返回的
数据多的时候有几千条,源表的数据量有的也有几十万条,导致表值函数中的表变量
在操作的时候速度很慢!

  • 写回答

3条回答 默认 最新

  • 邪恶八进制 2018-06-12 02:26
    关注

    1.把表值函数重写为内联表值函数或将表值函数的结果存入临时表再进行Join可提升性能。如果表值函数只是返回一张表,则可以使用内联表值函数代替多语句表值函数,也可不使用自定义函数的语句。参考:https://m.imooc.com/article/details?article_id=26245
    2、将CROSS APPLY改写成INNER JOIN ,以减少多语句表值函数的调用次数
    3、对于和表值函数做Apply或表值函数返回的行数非常小的查询,或许并不影响。但对于返回结果较多的表值函数做Join,则可能产生性能问题,因此如果有可能,把表值函数重写为内联表值函数或将表值函数的结果存入临时表再进行Join可提升性能。

    当然,不是所有的多语句表值函数都可以被改写,在优化时测试各种优化方案,寻找到一种最适合业务场景的方法。
    标志函数为什么会有性能问题,参考:https://www.cnblogs.com/CareySon/p/4269897.html

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 删除虚拟显示器驱动 删除所有 Xorg 配置文件 删除显示器缓存文件 重启系统 可是依旧无法退出虚拟显示器
  • ¥15 vscode程序一直报同样的错,如何解决?
  • ¥15 关于使用unity中遇到的问题
  • ¥15 开放世界如何写线性关卡的用例(类似原神)
  • ¥15 关于并联谐振电磁感应加热
  • ¥15 this signal is connected to multiple drivers怎么解决
  • ¥60 请查询全国几个煤炭大省近十年的煤炭铁路及公路的货物周转量
  • ¥15 请帮我看看我这道c语言题到底漏了哪种情况吧!
  • ¥66 如何制作支付宝扫码跳转到发红包界面
  • ¥15 pnpm 下载element-plus