• 首页
  • 国产小呦泬泬99精品
  • 最近2019中文字幕在线高清
  • 免费看少妇作爱视频
  • 曰批全过程免费视频在线观看网站
  • 国色天香在线观看全集免费播放
  • 婆岳同床双飞呻吟
  • 婆岳同床双飞呻吟你的位置:三级小说 > 婆岳同床双飞呻吟 > SQL行转列诓骗的动态杀青面孔

    SQL行转列诓骗的动态杀青面孔

    发布日期:2022-06-18 17:11    点击次数:135

    SQL行转列诓骗的动态杀青面孔

    综合:

    SQL行转列的需求,在式样中如故宽泛可见的,尤其报表类的诓骗,更辱骂常平淡!上期咱们讲了SQL行转列的静态杀青面孔,本期搞一下行转列的动态杀青决议,处分决议并不独一,这里采取存储经由的杀青面孔!

     

    SQL行转列诓骗的动态杀青面孔

     

    接下来咱们瞩目西宾下SQL动态行转列的杀青重要: 创建模拟数据:

    这里如故腐烂路,IT编程人初学的经典学生选课表系列,学生表、课程表、收获表!就拿这套见闻习染的表结构进行西宾!

     

    SQL行转列诓骗的动态杀青面孔

     

     

    SQL行转列诓骗的动态杀青面孔

     

    插入模拟的数据,用于动态行转案例的使用!

     

    SQL行转列诓骗的动态杀青面孔

     

    先写好静态行转列SQL:

    这一步相对如故相比重要,毕竟咱们要在一个静态的行转列基础之上,构建动态的行转列诓骗,课程数据会有动态变化,学生也会采取新开的课程,这么静态模式例必不会灵验,但参照静态模板,去开荒动态的模式,则愈加有参照性!

     

    SELECT S.SID,S.sname,  MAX(case c.cname when '数学' then sc.score else 0 end) as 数学, MAX(case c.cname when '语文' then sc.score else 0 end) as 语文, MAX(case c.cname when '英语' then sc.score else 0 end) as 英语 FROM Student as S LEFT JOIN SC AS SC ON S.sid = SC.SID LEFT JOIN Course AS C ON C.cid = SC.CID GROUP BY S.sid,
    天天躁日日躁狠狠躁日日躁黑人S.sname 

     

     

    SQL行转列诓骗的动态杀青面孔

     

    通过测试,数据后果莫得问题,恰是咱们期待的面孔!

    编写动态剧本:

    动态行转列无疑需要使用SQL编程的时刻,动态的递归课程称号,这么才不错暂劳永逸的处分问题!

    先编写动态的SQL剧本:

     

    DECLARE @SQL VARCHAR(MAX)  SELECT @SQL = ' SELECT S.SID,S.SNAME ' SELECT @SQL = @SQL + ' , ISNULL(MAX(CASE c.cname WHEN '''+cname+''' THEN sc.score END ),0) AS '''+c.cname+''' '  FROM Course  AS C  print @sql  SELECT @SQL = @SQL + ' FROM Student as S LEFT JOIN SC AS SC ON S.sid = SC.SID LEFT JOIN Course AS C ON C.cid = SC.CID  GROUP BY S.sid,S.sname'  print @sql  EXEC (@SQL) 

     

    测试约束与静态SQL齐全一致,看来问题也曾处分,接下来即是优化的问题了!

     

     

    将上述的动态剧本封装成存储经由,婆岳同床双飞呻吟第一不错尽量地擢升查询着力,第二浅薄代码段的调用!

     

    CREATE PROC StudentScore_Proc AS BEGIN   DECLARE @SQL NVARCHAR(MAX)  SELECT @SQL = N' SELECT S.SID,S.SNAME ' SELECT @SQL = @SQL + N' , ISNULL(MAX(CASE c.cname WHEN '''+cname+''' THEN sc.score END ),0) AS '''+c.cname+''' '  FROM Course  AS C   SELECT @SQL = @SQL + N' FROM Student as S LEFT JOIN SC AS SC ON S.sid = SC.SID LEFT JOIN Course AS C ON C.cid = SC.CID  GROUP BY S.sid,S.sname'  print @sql  EXECUTE sp_executesql @STMT = @SQL  END  EXEC dbo.StudentScore_Proc 

     

    封装完存储经由,咱们再试验一下,望望约束!真实莫得任何问题,与预期齐全一致!

     

     

    这时辰咱们变嫌一下数据,课程表中新增物理、化学两门课程,诺克萨斯之手区分采取了两门课程,盖伦只是采取了化学,火器群众逃学,俩门课都莫得采取。

     

    INSERT INTO Course SELECT 4,'物理' INSERT INTO Course SELECT 5,'化学'  INSERT INTO SC SELECT 1,4,99 INSERT INTO SC SELECT 1,5,88 INSERT INTO SC SELECT 2,5,77  EXEC dbo.StudentScore_Proc 

     

    数据改变之后,咱们陆续测试一下,再次试验咱们编写好的存储经由,约束额外无缺,跟着数据的变化,查询的约束集亦然对应的变化,额外NICE,大功凯旋了!

     

     

    转头一下:

     

    贯穿俩篇的著述更新,SQL行转列在式样中的诓骗都也曾涵盖了。行将步入年底了,详情有好多小伙伴被客户、教导追着搞多样报表,但愿对小伙伴们有多少的匡助。

     



    Powered by 三级小说 @2013-2022 RSS地图 HTML地图