T-Sql(四)表关联和视图(view)

系统 1590 0
原文: T-Sql(四)表关联和视图(view)

今天讲下T-sql中用于查询的表关联和视图,我们平时做项目的时候会遇到一些复杂的查询操作,比如有班级表,学生表,现在要查询一个学生列表,要求把学生所属班级名称也查询出来,这时候简单的select查询就不行了,需要关联班级表,因为学生是一定属于某一个班级的,所以关联的示例需要自关联。

表关联(join)  

  下面列一些示例代码,帮助大家理解。

      
        select
      
       t2.
      
        *
      
      
        --
      
      
        表自关联
      
      
        from
      
      
         Tree t1


      
      
        inner
      
      
        join
      
      
         Tree t2


      
      
        on
      
       t1.NO
      
        =
      
      
        t2.ParentNo


      
      
        where
      
       t1.Name
      
        =
      
      
        '
      
      
        Node1_2
      
      
        '
      
      
        ;




      
      
        select
      
      
        *
      
      
        from
      
       tree      
      
        --
      
      
        子嵌套查询
      
      
        where
      
       ParentNo 
      
        =
      
       (
      
        select
      
       NO 
      
        from
      
       tree 
      
        where
      
       Name 
      
        =
      
      
        '
      
      
        Node1_2
      
      
        '
      
      
        );




      
      
        select
      
      
        *
      
      
        from
      
      
         tree 


      
      
        where
      
       parentNo 
      
        in
      
       (
      
        select
      
       no 
      
        from
      
       tree 
      
        where
      
       Name 
      
        =
      
      
        '
      
      
        Node1_2
      
      
        '
      
      );
    

上面是表自关联,关键字inner,就是返回t1.NO = t2.ParentNo 条件的所有t2表的数据,

  有表自关联,当然还有左关联,右关联,示例代码:

      
        select
      
       t2.
      
        *
      
      
        --
      
      
        左关联
      
      
        from
      
      
         Tree t1


      
      
        left
      
      
        join
      
      
         Tree t2


      
      
        on
      
       t1.NO
      
        =
      
      
        t2.ParentNo


      
      
        where
      
       t1.Name
      
        =
      
      
        '
      
      
        Node1_2
      
      
        '
      
      
        ;




      
      
        select
      
       t2.
      
        *
      
      
        --
      
      
        右关联
      
      
        from
      
      
         Tree t1


      
      
        right
      
      
        join
      
      
         Tree t2


      
      
        on
      
       t1.NO
      
        =
      
      
        t2.ParentNo


      
      
        where
      
       t1.Name
      
        =
      
      
        '
      
      
        Node1_2
      
      
        '
      
      ;
    

视图View

视图的关键字是View,就是一个查询集合,方便我们去查询数据,视图其实就是表,多表连接的表,我们查询的时候不需要反复的去拼接语句,直接查询视图就可以,方便我们的操作,当然一些简单的查询操作就没必要去创建视图了。

  示例代码:

      
        create
      
      
        view
      
      
         Production.vw_Product


      
      
        as
      
      
        select
      
       t1.
      
        *
      
      
        from
      
      
         Production.Product t1

    
      
      
        left
      
      
        outer
      
      
        join
      
       Production.ProductModel t2 
      
        on
      
       t2.ProductModelID
      
        =
      
      
        t1.ProductModelID

    
      
      
        left
      
      
        outer
      
      
        join
      
       Production.ProductSubcategory t3 
      
        on
      
       t3.ProductSubcategoryID
      
        =
      
      
        t1.ProductSubcategoryID

    
      
      
        left
      
      
        outer
      
      
        join
      
       Production.UnitMeasure t4 
      
        on
      
       t4.UnitMeasureCode
      
        =
      
      t1.SizeUnitMeasureCode 
      
        and
      
       t4.UnitMeasureCode
      
        =
      
      
        t1.SizeUnitMeasureCode

    
      
      
        --
      
      
        order by t1.ProductID
      
    

查询视图:

      
        select
      
      
        *
      
      
        from
      
       Production.vw_Product
    

表关联和视图都是比较简单的数据库操作,但也是比较常用的。大家好好练习。

  还有一些相关编程知识的整理,希望大家关注下。。。

 

T-Sql(四)表关联和视图(view)


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论