不神奇 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 Ubuntu开机显示器只显示kernel,是没操作系统(相关搜索:显卡驱动)
  • ¥15 VB.NET如何绘制倾斜的椭圆
  • ¥15 在rhel8中安装qemu-kvm时遇到“cannot initialize crypto:unable to initialize gcrypt“报错”
  • ¥15 arbotix没有/cmd_vel话题
  • ¥15 paddle库安装时报错提示需要安装common、dual等库,安装了上面的库以后还是显示报错未安装,要怎么办呀?
  • ¥20 找能定制Python脚本的
  • ¥15 odoo17的分包重新供应路线如何设置?可从销售订单中实时直接触发采购订单或相关单据
  • ¥15 用C语言怎么判断字符串的输入是否符合设定?
  • ¥15 通信专业本科生论文选这两个哪个方向好研究呀