首页 > 数据库 >SQL 查询优化指南:SELECT、SELECT DISTINCT、WHERE 和 ORDER BY 详解

SQL 查询优化指南:SELECT、SELECT DISTINCT、WHERE 和 ORDER BY 详解

时间:2023-11-17 21:00:12浏览次数:34  
标签:Customers DISTINCT 选择 排序 WHERE ORDER SELECT

SELECT 关键字

SQL的SELECT语句用于从数据库中选择数据。SELECT语句的基本语法如下:

SELECT column1, column2, ...
FROM table_name;

其中,column1, column2,等是您要从表中选择的字段名称,而table_name是您要选择数据的表的名称。

如果要选择表中的所有列,您可以使用SELECT *语法。

以下是一些示例:

  1. 从Customers表中选择CustomerNameCity列的数据:
SELECT CustomerName, City FROM Customers;
  1. 从Customers表中选择所有列的数据:
SELECT * FROM Customers;

这些语句将返回符合条件的数据记录,您可以根据需要选择特定的列或所有列。

SELECT DISTINCT 关键字

SQL的SELECT DISTINCT语句用于选择表中的不同(唯一)值。这在某些情况下非常有用,因为数据库表中的某些列可能包含大量重复值,而您只关心获取这些值的不同实例。

SELECT DISTINCT的基本语法如下:

SELECT DISTINCT column1, column2, ...
FROM table_name;

其中,column1, column2,等是您要选择不同值的列名称,而table_name是您从中选择不同值的表的名称。

以下是一些示例:

  1. 从"Customers"表中选择不同的国家:
SELECT DISTINCT Country FROM Customers;

这将返回"Customers"表中不同国家的列表。

  1. 计算不同国家的数量:
SELECT COUNT(DISTINCT Country) FROM Customers;

此语句使用COUNT函数来计算不同国家的数量。

请注意,某些数据库系统可能不支持COUNT(DISTINCT column_name)这种写法。在这种情况下,您可以使用子查询来达到相同的目的。

SQL WHERE 关键字

SQL的WHERE子句用于筛选数据库表中的记录。它允许您提取只满足指定条件的记录。以下是基本的WHERE子句语法:

SELECT column1, column2, ...
FROM table_name
WHERE condition;
  • column1, column2,等是您要选择的列名称。
  • table_name是您从中选择记录的表的名称。
  • condition是用于筛选记录的条件。

condition中,您可以使用各种运算符来定义筛选条件。以下是一些示例:

  1. 选择所有来自墨西哥的客户:
SELECT * FROM Customers
WHERE Country='Mexico';
  1. 选择CustomerID大于80的所有客户:
SELECT * FROM Customers
WHERE CustomerID > 80;
  1. 选择CustomerName不等于"Alfreds Futterkiste"的客户:
SELECT * FROM Customers
WHERE CustomerName <> 'Alfreds Futterkiste';
  1. 选择邮政编码在特定范围内的客户:
SELECT * FROM Customers
WHERE PostalCode BETWEEN '05020' AND '05030';
  1. 选择联系人名字以"M"开头的客户:
SELECT * FROM Customers
WHERE ContactName LIKE 'M%';
  1. 选择Country为"USA"或"Canada"的客户:
SELECT * FROM Customers
WHERE Country IN ('USA', 'Canada');

注意:在condition中,文本字段的值需要用单引号括起来,而数值字段则不需要。运算符的使用取决于您的筛选需求,可以根据需要进行选择。

ORDER BY 关键字

SQL的ORDER BY关键字用于对结果集进行排序,您可以按升序(ASC)或降序(DESC)进行排序。以下是ORDER BY关键字的基本语法:

SELECT column1, column2, ...
FROM table_name
ORDER BY column1, column2, ... ASC|DESC;
  • column1, column2,等是您要选择的列名称。
  • table_name是您从中选择记录的表的名称。
  • ORDER BY后面的列名是您要用于排序的列。
  • 您可以使用ASC(默认,升序)或DESC(降序)来指定排序的方向。

以下是一些示例:

  1. 按价格对产品进行升序排序:
SELECT * FROM Products
ORDER BY Price;
  1. 按价格对产品进行降序排序:
SELECT * FROM Products
ORDER BY Price DESC;
  1. 按产品名称升序排序:
SELECT * FROM Products
ORDER BY ProductName;
  1. 按产品名称降序排序:
SELECT * FROM Products
ORDER BY ProductName DESC;
  1. 按国家升序排序,如果有相同国家的客户,则按客户名称降序排序:
SELECT * FROM Customers
ORDER BY Country, CustomerName;
  1. 同时按国家升序排序并按客户名称降序排序:
SELECT * FROM Customers
ORDER BY Country ASC, CustomerName DESC;

ORDER BY关键字使您可以以不同的方式对查询结果进行排序,以满足不同的需求。

最后

为了方便其他设备和平台的小伙伴观看往期文章:公众号搜索Let us Coding,或者扫描下方二维码,关注公众号,即可获取最新文章。

看完如果觉得有帮助,欢迎点赞、收藏关注

image

标签:Customers,DISTINCT,选择,排序,WHERE,ORDER,SELECT
From: https://www.cnblogs.com/xiaowange/p/17839677.html

相关文章

  • Dapper QueryMultiple throws "No columns were selected"
    调试存储过程发现某字段NULL,拼成的SQL最后啥也没有了。。。原因是存储过程没有执行到查询SQL语句QueryAsyncthrows"Nocolumnswereselected"whenstoredprocdoesn'tperformaselectstatement #591Closed  toannguyen83 openedthisissue onAug27,20......
  • Java IO --- select,poll,epoll
    一、select、poll、epollselect、poll、epoll都是IO多路复用的机制且本质上都是同步I/O。IO多路复用就是通过一种机制,可以同时监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知进行相应的读写操作。1.1selectintselect(intn,fd_set*readfds,fd_set*writefd......
  • 1.一条select语句执行流程
    一条SQL语句查询过程一条SQL执行过过程会经过连接器、查询缓存、解析器、执行器以及存储引擎等组件,执行过程图(仿小林coding)如下:MYSQL架构分为Server层和存储引擎层。Server层负责建立连接、分析和执行SQL;存储引擎负责数据的存储和提取。连接器:TCP三次握手建立连接、校......
  • element中select组件加入滚动分页及模糊查询
    element中select组件加入滚动分页及模糊查询1.directive.js-自定义vue指令importVuefrom'vue'exportdefault()=>{Vue.directive('loadMore',{bind(el,binding){//如上图,我通过v-if来控制了两个select框,当没有binding.arg这个参数时,我只能监听到企......
  • Get distinct count of rows in the DataSet
    ThetableintheDataSetisasfollows:Column1    Column211              A11              B22              C33              D33              E44              F Dist......
  • docker使用--gpus all报错: docker: Error response from daemon: could not select d
    报错信息:docker:Errorresponsefromdaemon:couldnotselectdevicedriver""withcapabilities:[[gpu]].解决方法:1,任意路径下创建nvidia-container-runtime-script.sh文件vimnvidia-container-runtime-script.sh拷贝下方内容到nvidia-container-runtime-script.......
  • 解决复制select下拉框时 值没法复制的问题
     tip:当选择下拉框某个值时,f12查看到的option并没有自动添加selected属性,所以复制时下拉框的值没法复制的,这时需要clone函数来复制并通过循环原来的select复制选中的值 <inputtype='button'value='复制'  onclick='copyRow(this)'/>//复制当前行,dom元素的复制,不会刷新当前页......
  • Left Join,Right Join,Inner Join与where连接的区别
    概述连表是SQL常用的操作,但是连表不一样,得到的结果也不一样(在数据量大的时候尤为明显),这里就是对关联表中一些筛选用的关键字的具体区别做了一个详细的梳理。首先准备两张表,分别是tb_student和tb_class表 tb_class表:tb_student表:一、内连接1、隐式内连接:把连接条件放......
  • oracle中insert用select方式插入慢的解决之一
    原理我没明白,但是可以解决插入过慢的问题。原SQLINSERT INTO LOGINSTATBYDEPTzsy(group_id, persons, loginTimes, loginPersons, datadate, TYPE)SELECT tg.id, p.persons, sum(lb.LOGINAMOUNT)sum1, count(DISTINCTtu.id)sum2, 1, 2FROM userdaylogini......
  • element中的el-select下拉框多选显示的tags文本内容过长导致显示溢出框外
      /*select多选tags超出省略显示*/.el-select__tags-text{ display:inline-block; max-width:60px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}.el-select.el-tag__close.el-icon-close{ top:-7px;}......