前路漫漫兮 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 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)
  • ¥20 matlab yalmip kkt 双层优化问题
  • ¥15 如何在3D高斯飞溅的渲染的场景中获得一个可控的旋转物体
  • ¥88 实在没有想法,需要个思路