zoukankan      html  css  js  c++  java
  • 【SQL server】SQL server基础(一)

    一、关系型数据库

      关系型数据库的基本元素是二维表,这些二维表可以被独立或者通过join语句连接起来使用。主键和外键是用来连接二维表之间的主要工具

      1.主键(primary key)和外键(foreign key)

        主键是来唯一的标识一行数据,而且主键列必须包含唯一值,且不能包含空值(null)

        主键可以建立在每张二维表的单列或多列上

        一张二维表的外键可以引用某张二维表对应的主键

        

      2.数据库中的关系表

        

    二、SQL语句

      1.sql的基本语句   

        SELECT <table fields list>
        FROM <table names list>
        WHERE <row constraints specification>
        GROUP BY <grouping specification>
        HAVING <grouping selection specification>
        ORDER BY <order rules specification>

        *SELECT...FROM..语句是必须的,从某个表选择某列

          WHERE  对行进行限制,例如筛选ID>9,则小于等于9的行就被过滤

          GROUPBY 集合运算时添加的一些定义,例如计算age平均值

          HAVING 针对集合运算进行限制条件,例如average age>30

         ORDERBY 排列,例如有ID,name,age等列,想按照ID排列则可以 ORDERBY ID

      2.SELECT....FROM关键字

         1)SELECT....FROM

     1 select * from [Production].[Product]                                         --*表示所有
     2 
     3 select ProductID, Name, ProductNumber, Color, Size, ListPrice                --从表中显示指定列
     4 from Production.Product
     5 
     6 select ProductID, Name, ProductNumber, Color, Size, ListPrice 
     7 from Production.Product
     8 order by listprice desc --desc=descending order ; asc=ascending order        --按照listprice的降序显示
     9 
    10 select ProductID, Name, ProductNumber, Color, Size, ListPrice 
    11 from Production.Product
    12 order by listprice desc,Name                                                 --按照listprice的降序,Name的升序显示(没有写des或asc默认以升序排列)
    13 
    14 select ProductID, Name, ProductNumber, Color, Size, ListPrice 
    15 from Production.Product
    16 order by 2                                         --2表示Name,按照Name的升序排列,3表示ProductNumber

         2)isnull函数,判断是否为空

    select ProductID, Name, ProductNumber, isnull(Color,''), isnull(Size,''), ListPrice    --将color,size中的空值null替换为‘ ’,列名也为空
    from Production.Product
    
    select ProductID, Name, ProductNumber, 
    isnull(Color,'') as Color, isnull(Size,'') as Size123, --using an alias                --as..修改列名
    ListPrice 
    from Production.Product

        执行该语句后:

        3)"+"关键字:将列与字符串连接

    1 select ProductID, Name as ProductName,        --using an alias
    2 'The ProductNumber ' + ProductNumber + '.'as ProductNumber ,   --using the concatenation to join character end-to-end.
    3 'The list price for ' + ProductNumber + ' is $ ' + convert(varchar,ListPrice) +'.' as [Description] --convert函数转换类型
    4 from [Production].[Product]

        执行后:

                        

        4)算数表达式

    1 select BusinessEntityID
    2 ,rate*40*52 as AnnualSalary                                  --Annual salary的值为rate*40*52
    3 ,round(rate*40*52,1) as AnnualSalary                         --rate*40*52,结果保留一位小数
    4 ,round(rate*40*52,0) as AnnualSalary                         --rate*40*52,结果保留两位小数
    5 from [HumanResources].[EmployeePayHistory]

      3.WHERE..关键字

        WHERE 子句中的运算符

          

        1)or 或and

    1 select SalesOrderID,OrderDate,SalesPersonID,TotalDue as TotalSales 
    2 from [Sales].[SalesOrderHeader]
    3 where SalesPersonID=275 and TotalDue>5000 and Orderdate between '2005-08-01' and '1/1/2006'           --比较符=,>,<,>=,<=,<>,and且,or或orderdate在2005-08-1到2006-01-01之间
    4 
    5 select SalesOrderID,OrderDate,SalesPersonID,TotalDue as TotalSales 
    6 from [Sales].[SalesOrderHeader]
    7 where SalesPersonID=275 and TotalDue>5000 and Orderdate >= '2005-08-01' and Orderdate < '1/1/2006'    --orderdate大于等于2005-08-01且小于等于2006-01-01
    1 select SalesOrderID,OrderDate,SalesPersonID,TotalDue as TotalSales 
    2 from [Sales].[SalesOrderHeader]
    3 where (SalesPersonID=275 or SalesPersonID=278)  and TotalDue>5000                                     --ID=275或278中 Due>5000的结果

        2)like“%”或“_”通配符

     1 select * from [Production].[Product]
     2 where name like'Mountain'                                                                 --name ='Mountain'
     3 
     4 select * from [Production].[Product]
     5 where name like'%Mountain%' --Wildcard % matches any zero or more characters              --筛选出name中含有Mountain的结果,例如...Mountain...,Mountain...,...Mountain
     6 
     7 select * from [Production].[Product]
     8 where name like'mountain%' -- "_" matches any single character                            --筛选出name中以Mountain开头的结果,例如Mountain....
     9 
    10 select * from [Production].[Product]
    11 where name like'_ountain%'                                                                --‘_’表示任意字符,如countains

         3)in 和not in

    1 select * from [Production].[Product]
    2 where color in ('red','white','black')                   --即color='red' or color='white' or color='black'
    3 
    4 select * from [Production].[Product]
    5 where class not in ('H') -- same as using: <> 'H'        --即clas <>'H',有些地方不等于可以用!=

        4)is null 和is not null

      3.聚合函数

        1)常用函数

     1 select count(SalesPersonID)              --计算数量
     2 from [Sales].[SalesOrderHeader]
     3 where SalesPersonID is not null
     4 
     5 select distinct(SalesPersonID)           --列出不同的值,如有1,1,1,2,2,3,4,则结果为1,2,3,4
     6 from [Sales].[SalesOrderHeader]
     7 where SalesPersonID is not null
     8 
     9 select count(distinct(SalesPersonID))    --计算不同值的数量
    10 from [Sales].[SalesOrderHeader]
    11 where SalesPersonID is not null

        2)集合运算

    1 select 
    2 Avg(TotalDue) as AverageTotalSales        --取平均值
    3 ,Min(TotalDue) as MinimumTotalSales       --取最大值
    4 ,Max(TotalDue) as MaximumTotalSales       --取最小值
    5 ,Sum(TotalDue) as SummaryTotalSales       --取总和
    6 from [Sales].[SalesOrderHeader]

         *注,如果select中同时包含集合函数和非集合函数,则非集合函数要放到group by中

    1 select SalesPersonID,Max(TotalDue) as MaximumTotalSales 
    2 from [Sales].[SalesOrderHeader]
    3 where SalesPersonID is not null
    4 group by SalesPersonID                                         --取每个salespersonID对应的最大值
    5 order by SalesPersonID

        3)经典的T-SQL语句

    1 select SalesPersonID,OrderDate,Max(TotalDue) as MaximumTotalSales       --结果显示的列
    2 from [Sales].[SalesOrderHeader]
    3 where SalesPersonID is not null and OrderDate >='2007/1/1'        --限制条件为ID不为空,orderdate大于等于2007-01-01
    4 group by SalesPersonID,OrderDate 
    5 having Max(TotalDue)>150000                                            --筛选出total due大于1500000的对应信息
    6 order by OrderDate desc                             --以order date降序排列
  • 相关阅读:
    c#对文件的读写
    win form treeview添加节点
    泛型的学习
    委托学习
    C#连接Oracle数据库解决报错(需要安装Oracle客户端软件8.1.7)的问题
    C#和Python 图片和base64的互转
    反射学习:(System.Reflection)
    objectivec:继承
    prism关键概念:
    三层架构的学习感悟(一)
  • 原文地址:https://www.cnblogs.com/dhs94/p/10247586.html
Copyright © 2011-2022 走看看