关于SQL查询语句关键字方法

 更新时间:2022年10月31日 11:20:59   作者:我家有只小熊二  
这篇文章主要介绍了关于SQL查询语句关键字方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

SQL常用的一些关键字

1、distinct关键字

显示没有重复记录的商品名称,商品价格和商品类别列表

select distinct ware_name,price from t_ware;

2、使用计算列

查询所有商品价格提高20%后的价格

select ware_id,ware_name,price*1.2 from t_ware'

3、列的别名

a) 不使用as

select ware_id,ware_name,price*1.2 price_raise 
from t_ware;

b)使用as

select ware_id,ware_name,price*1.2 price_raise 
from t_ware;

4、使用逻辑表达式

a)not 显示商品价格不大于100的商品

select ware_id,ware_name,price,category_id 
from t_ware 
where not price>100;

b)or 显示商品类别编号为5或6或7的商品

select ware_id,ware_name,price,category_id 
from t_ware 
where category_id=5 or category_id=6 
or category_id=7;

c)and 显示商品价格大于100且商品类别编号为5的商品

select ware_id,ware_name,price,category_id 
from t_ware 
where not price>100 and category_id = 5;

5、使用between关键字

显示商品价格在200元至1000元之间的商品(留心一下,是半开区间还是封闭区间?)

select ware_id,ware_name,price,category_id 
from t_ware 
where price between 200 and 1000;

6、使用in关键字

显示商品类别为5,6,7且价格不小于200元的商品

select ware_id,ware_name,price,category_id 
from t_ware 
where category_id in (5,6,7) and price>=200;

7、使用like子句进行模糊查询

a)%(百分号)表示0到n个任意字符

select ware_id,ware_name,price,category_id 
from t_ware 
where ware_name like '%纯棉%';

b)_(下划线)表示单个的任意字符

select ware_id,ware_name,price,category_id 
from t_ware 
where ware_name like  '%长袖_恤%';

8、转义字符escape的使用

select ware_id,ware_name,price,category_id 
from t_ware 
where ware_name like '%\%%' escape '\';

9、使用order by给数据排序

    select * from t_ware_category 
    where parent_id = 0 order by ware_id ;
    --------
    select * from t_ware_category 
    where parent_id = 0 order by ware_id asc;
    ---------
    select * from t_ware_category
    where parent_id = 0 order by ware_id desc ;

rownum

a)查询前20条商品记录

select ware_id,ware_name,price 
from t_ware 
where rownum <= 20;

b)查询第11条至第20条记录

select ware_id,ware_name,price
from t_ware 
where rownum<=10 and ware_id 
not in(select ware_id from t_ware where rownum<=10);

10、常用统计函数

a) sum()返回一个数字列或计算列的总和

select sum(price) from t_ware;

b) avg()对一个数字列或计算列球平均值

c) min()返回一个数字列或一个数字表达式的最小值

d) max()返回一个数字列或一个数字表达式的最大值

e) count()返回满足select语句中指定的条件的记录值

11、多表查询和笛卡尔乘积

查询商品编号,商品名称,商品价格和商品类别名称

select 
t_ware.ware_id, t_ware.ware_name, t_ware.price ,t_ware_category_name 
from t_ware, t_ware_category  
where t_ware.category_id=t_ware_category.category_id;

使用join

a)左连接

select 
t_ware.ware_id,t_ware.ware_name,t_ware.price,t_ware_category.category_name 
from t_ware 
left join t_ware_category 
on t_ware.category_id=t_ware_category.category_id;
select w.ware_id,w.ware_name,w.price,wc.category_name 
from t_ware w 
left join t_ware_category wc 
on w.category_id=wc.category_id;

b) 右连接

select t_ware.ware_id,t_ware.ware_name,t_ware.price,t_ware_category.category_name
from t_ware 
left join t_ware_category 
on t_ware.category_id=t_ware_category.category_id;

12、使用union

select ware_id,ware_name 
from t_ware 
where ware_name like '%T恤%' 
union 
select ware_id,ware_name
 from t_ware 
 where ware_name like '%手提包%'

13、使用group by

a)统计每个二级类别下有多少商品,以及商品总价值

select w.category_id,wc.category_name,
count(w.ware_id),sum(w.price) 
from t_ware w 
left join t_ware_category wc 
on w.category_id=wc.category_id 
group by w.category_id,wc.category_name;

b) 统计每个一级类别下有多少商品,以及商品总价值

select wc2.category_id,wc2.category_name,sum(w.price) 
from t_ware w 
left join t_ware_category wc 
on w.category_id=wc.category_id 
left join t_ware_category wc2 
on wc.parent_id=wc2.category_id 
group by wc2.category_id,wc2.category_name;

14、使用having对结果进行筛选

–举例子说明:查询table表查询每一个班级中年龄大于20,性别为男的人数

select COUNT(*)as '>20岁人数',classid  
from Table1 
where sex='男' 
group by classid,age having age>20 

需要注意说明:当同时含有where子句、group by 子句 、having子句及聚集函数时,执行顺序如下:

执行where子句查找符合条件的数据;

使用group by 子句对数据进行分组;对group by 子句形成的组运行聚集函数计算每一组的值;最后用having 子句去掉不符合条件的组。

  • having 子句中的每一个元素也必须出现在select列表中。有些数据库例外,如oracle.
  • having子句和where子句都可以用来设定限制条件以使查询结果满足一定的条件限制。
  • having子句限制的是组,而不是行。where子句中不能使用聚集函数,而having子句中可以。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • SqlServer 实用操作小技巧集合

    SqlServer 实用操作小技巧集合

    包括安装时提示有挂起的操作、收缩数据库、压缩数据库、转移数据库给新用户以已存在用户权限、检查备份集、修复数据库等.
    2009-10-10
  • Filestream使用简单步骤总结

    Filestream使用简单步骤总结

    这篇文章主要介绍了Filestream使用简单步骤总结,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • sql server中错误日志errorlog的深入讲解

    sql server中错误日志errorlog的深入讲解

    很多时候诊断SQLSERVER问题都需要看SQLSERVER的错误日志,所以下面这篇文章主要给大家介绍了关于sql server中错误日志errorlog的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-10-10
  • SQL Server向表中插入数据的三种方式

    SQL Server向表中插入数据的三种方式

    这篇文章主要介绍了SQL Server向表中插入数据的三种方式,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-04-04
  • MSSQL中递归SQL查询语句实例说明-

    MSSQL中递归SQL查询语句实例说明-

    MSSQL中递归SQL查询语句分享,需要的朋友可以参考下。
    2011-09-09
  • sql字符串函数大全和使用方法示例

    sql字符串函数大全和使用方法示例

    本文主要讲解SQL SERVER的字符串函数使用方法,包括LEN、LOWER、UPPER (string)、LTRIM、RTRIM等函数
    2014-01-01
  • sql中常见的四种排名函数的用法

    sql中常见的四种排名函数的用法

    本文主要介绍了sql中常见的四种排名函数的用法,主要包括row_number,rank,dense_rank,ntile,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • SQL Server使用xp_readerrorlog命令查看错误日志

    SQL Server使用xp_readerrorlog命令查看错误日志

    本文探讨了SQL Server中查看日志的四种方法,重点介绍了xp_readerrorlog命令的使用方法,xp_readerrorlog命令用于T-SQL读取SQL Server错误日志,有助于对SQL Server中的问题进行故障排除,避免因特定情况而从GUI读取大型错误日志的麻烦
    2025-03-03
  • SQL Server日志清理3种实现方式

    SQL Server日志清理3种实现方式

    这篇文章主要给大家介绍了关于SQL Server日志清理3种实现方式的相关资料,在数据库使用很久后日志文件会累计的越来越大,如果硬盘空间不足可能会导致宕机,需要的朋友可以参考下
    2023-09-09
  • SQL Server附加数据库报错无法打开物理文件,操作系统错误5的图文解决教程

    SQL Server附加数据库报错无法打开物理文件,操作系统错误5的图文解决教程

    sqlserver附加数据时,提示无法打开物理文件,操作系统错误5什么原因呢?今天小编给大家分享SQL Server附加数据库报错无法打开物理文件,操作系统错误5的图文解决教程,一起看看吧
    2016-12-12

最新评论