不神奇 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 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器