不神奇 2018-06-23 02:55 采纳率: 0%
浏览 806
已采纳

关于sql 动态获取数据的效率问题

场景:有10万+用户 ;假设每个用户对表A的获取的字段都不一样;比如:

1)张三需要表A中的字段a、b、c...
2)李四需要表A中的字段a、b、d...
3)王五需要表A中的字段a、c、d...
4)王六需要表A中的字段b、c、f...
...

请问如果用动态sql语句根据需求去获取是否是最佳的方式?效率如何?
select a,b,c from A
....

  • 写回答

4条回答 默认 最新

  • zhutou0071 2018-07-10 08:57
    关注

    建一张表,存储用户对A的需求字段(u_A)
    uid A表字段名(ua)
    u001 a,b,c,d
    u002 a,c,d,f,g
    ........
    建立存储过程
    CREATE PROCEDURE [dbo].[TEST1]
    @uid varchar(50)
    as
    begin
    declare @s1 nvarchar(max)
    set @s1='select '+(select ua from u_A where uid='''+@uid+''') from A'
    exec(@s1 )
    end

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

报告相同问题?

悬赏问题

  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题