不神奇 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 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵