SQL单表查询 SQL Server

本文介绍了SQL中的基本查询语法,包括选择列、筛选条件、分组统计、模糊查询、排序和别名设置。还提到了如COUNT、AVG等聚合函数的使用,以及CASEWHEN语句在处理不同情况时的应用。此外,还提及了获取当前日期和行号功能在数据检索中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

单表查询

  1. 简单的查询
select <查询列> as[别名] from <表名> where <条件>
  1. 各个关键字用法
    1. *(全部列)
    select * from <表名>
    
    1. where(原始表筛选条件)
    select <查询列> from <表名> where <条件>
    
    1. group by(分组)
    select <查询列> from <表名> group by <某列的元组>
    以某列中的元组为区分,这列元素相同的元组集和成一组
    PS: 统计公司在不同城市的客户数量
        select address as '城市',count(*)as '顾客数量' from customer group by address
    
    group by 之后,查询的列只能是聚合函数或者以某列分组的那一列
    4. like(模糊查询)
    select * from <表名> where <列名>like '___'
    '_'表示单个任意字符
    '%'表示任意多个字符
    PS:select * from employee where rtrim(emp_name) like '王__'
    
    1. order by(排序)
    select * from <表名> order by <列名> asc
    asc -- 升序
    desc --降序
    
    注意:order by之后,就不再是表了
    6. as(别名)
    select <列名> as <别名> from <表名>
    
    1. case when <情况一> then <处理一> when <情况二> then <处理二> end(同一列不同情况的不同处理)
    每个女性员工55岁,男性员工60岁退休
    计算查询每个员工的姓名,生日,入职时间以及他(她)的退休时间
    select emp_name,birthday,date_hired,
    case when sex = 'F' then dateadd(yy,55,birthday) 
    when sex = 'M' then dateadd(yy,60,birthday) end as '退休时间' 
    from  employee
    
  2. 聚合函数
    1. sum()求和
    2. count(*)元组个数
    3. count(<列名>)统计一列中值的个数
    4. avg()求平均值
    5. max()最大值
    6. min()最小值
  3. 常用函数
    1. getdate()取得当前系统时间
    2. year()对时间裁剪出年
    3. month()裁剪出月
    4. rtrim()删除右侧空格
    5. row_number()
    select <列名> row_number() over (order by spent desc) as rowID
    from <表名>
    offset <开始行数> rows fetch next <结束行数> rows only
    
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值