Sql_测试常用sql的关键字语句

本文介绍了SQL查询中的几个关键语句,包括Select查询、Where条件、子查询、ORDER BY排序、GROUP BY分组、HAVING条件关键字、Left/Right Join操作。详细解释了每个关键字的使用方法和示例,帮助读者理解SQL查询的书写顺序和应用场景。

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

Select 查询

查询表中的所有数据:SELECT * FROM 表名;
查询表中的A1,A2列的数据:SELECT A1,A2 FROM 表名;

where 条件语句

查询表中A1大于1的所有数据:SELECT * FROM 表名 WHERE A1>1;
查询表中A1大于1且A2大于1的所有数据:SELECT * FROM 表名 WHERE A1>1 AND A2>1;

子查询语句

id的结果从另一个语句中获取:SELECT * FROM A WHERE Id in (SELECT consignmentid FROM B);

ORDER BY 排序(desc降序 asc升序)

order by语句放在所有关键字以后,如条件语句(where),分组语句(group by)
根据字段CreationTime 升序:SELECT * FROM testconsignment ORDER BY CreationTime ASC;
根据字段CreationTime 升序:SELECT * FROM testconsignment ORDER BY CreationTime DESC;
语句放在分组和条件语句之后:SELECT count(*),LoginAccountName FROM driver GROUP BY LoginAccountName,IsStart HAVING IsStart=1 ORDER BY CreationTime DESC;

GROUP BY 分组查询

通过某字段或多个字段来分组,分组查询必须有如“count()”类似的函数,用于对结果集进行分组(例子:比如学习按照性别来统计人数,男性:30;女性:30用sql表示就是:
SELECT count(),sex FROM student GROUP BY sex;
分组查询:SELECT count(
),LoginAccountName FROM driver GROUP BY LoginAccountName
分组查询带条件就不再用“where”,而是用HAVING
SELECT count(*),LoginAccountName FROM driver GROUP BY LoginAccountName,IsStart HAVING IsStart=1 ORDER BY CreationTime DESC;

Having 条件关键字

用于有GROUP BY 分组查询后,用的条件语句:
SELECT count(*),LoginAccountName FROM driver GROUP BY LoginAccountName,IsStart HAVING IsStart=1 ORDER BY CreationTime DESC;

Left Join…On左关联/ Right Join…On右关联

左关联:返回左表(table1)所有行,即使没有匹配上右边表(table2)的的数据;
SELECT * FROM table1 A LEFT JOIN table2 B ON A.AccountName = B.LoginAccountName;
右关联:关键字会右表 (table2) 那里返回所有的行,即使在左表 (table1) 中没有匹配的行
SELECT * FROM table1 A LEFT JOIN table2 B ON A.AccountName = B.LoginAccountName;

sql书写顺序

在这里插入图片描述
以下两种表达查询结果一样:(以PlateNumber,CreateTime分组查询,并筛选条件CustomerId ,CreateTime,InterfaceType,再排序且聚合函数COUNT(PlateNumber)大于1的,最后取出两条数据)

  1. SELECT PlateNumber,CreateTime,COUNT(PlateNumber) as num FROM
    trackconsumelog WHERE CustomerId = “dxj00024” AND
    CreateTime>“2020-10-13” AND InterfaceType=1 GROUP BY
    PlateNumber,CreateTime HAVING COUNT(PlateNumber)>1 order by
    CreateTime desc limit 2;
  2. select * from ( SELECT PlateNumber,CreateTime,count(PlateNumber)
    as num,InterfaceType FROM trackconsumelog WHERE CustomerId =
    “dxj00024” and CreateTime >“2020-10-13” InterfaceType=1 group by
    PlateNumber,CreateTime order by CreateTime desc ) tt where tt.num >
    1 limit 2;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值