zoukankan      html  css  js  c++  java
  • 1.1(SQL学习笔记)SQL基础

    一、SELECT    

      建表及数据填充语句下载:链接: https://pan.baidu.com/s/1WHYafwqKJEKq1kDwCH_Zlg 提取码: 3wy4 

      SELECT用于指定检索返回的结果。(本例均采用mysql)

      FROM用于指定检索的表。

      例如:SELECT prod_name FROM products;

      会检索products表,返回prod_name列。

      

      运行结果如下

      

      SELECT中可以指定多个列,列名直接用“,”隔开。

      SELECT colName1,colName2,colName3... FROM tableName;

      

      如果需要返回所有列,可以采用“*”。

      SELECT * FROM tableName;返回指定表所有列。

      

      注:如果不是必须返回所有列,不要这样写,返回所有列会降低检索性能。

     

    二、ORDER BY

      检索出来所显示的数据的顺序是不确定的,这时需要人为对其排序。

      排序所使用的关键字为ORDER BY colName,后面加上排序所依据的列,也就是说按照(colName列)进行排序(默认升序)。

      ORDER BY需要放在最后面。

      

      指定了按prod_name排序(默认升序)。

      ORDER BY 后面可以指定多个列名,例如ORDER BY colName1,colName2,colName3...;

      排序时会先按colName1中数据进行比较进行排序,如果colName1中的数据相同无法,则按colName2中的数据进行排序。

      如果colName1可以区分出次序,则后续列名都不会起作用。

      例如上图中先按vend_id排序,在vend_id相同的情况下按照prod_price进行排序。

      

       之前说到默认排序是升序,那么必定有方法可以将其设置为降序。

       设置为降序需要通过DESC(descend)关键字来实现。升序:ASC(ascension )

       

      上图先采用vend_id升序排列,在vend_id相同的情况下采用prod_price进行降序排列。

      由于默认是升序,所以ASC可以不指定。(如果是升序可以不用添加,如果是降序则必须添加)

      如果要按多列进行降序排序,则每个列名后都需要添加DESC。

      

      

    三、WHERE

      上列通过SELECT * FROM tableName检索出来的数据是全部的数据。

      有没有办法只检索出我们需要的数据呢?例如所有单价为3.49的商品。

      这时就需要通过WHERE指定添加,即返回我们需要的数据。

      先看一个例子

      

      这里返回了所有prod_price小于5的商品信息。这里我们先来分析下执行顺序。

      首先执行FROM找到需要进行查询的表,然后执行WHERE语句,找出所有prod_price小于5的行。

      接着执行ORDER BY对其先按vend_id降序排序,然后再按prod_price升序排序。最后执行selece

      展示出检索结果的所有列。

      WHERE支持的操作符号有

      =:等于

      <>, !=:不等于。

      <:小于

      >:大于;

      <=

       >=

            !<:不小于,即大于等于。

      !>:不大于,即小于等于。

      BETWEEN:位于指定两个值之间。

      IS NULL:为null

     (不同的数据库管理软件对操作符的支持不太一样,某些数据库管理软件不支持某一些操作符,具体以查询相关文档为准。)

      注:WHERE的筛选条件中,如果值为数字不要加‘’(例如上例中的5),如果值为字符类型则需要添加‘’(例如下例中的‘DLL01’)。

      

      筛选出vend_id不等于‘DLL01’的商品。

      

      接下来我们试下BETWEEN,筛选出prod_price位于5-10之间的商品。

      

      指定在两个值之间,两个值需要使用AND连接。

      使用BETWEEN检索出来的结果会包含两端的值,即如果prod_price等于5,或等于10的商品也会被包含进来。

      [5,10]闭区间。

      

      IS NULL,检索指定列名中的属性为空的行。

      例如表中cust_email有两项为空,现在需要检索出cust_eamil为空的行。

      

      结果如下:

      

         

    参考资料:

    《SQL必知必会》 

  • 相关阅读:
    Spark Streaming反压机制
    spark submit参数及调优
    kafka中的配额管理(限速)机制
    Kafka限流
    BlockingQueue
    Android 更改userdata的大小
    visual studio 2019 error MSB3073 exited with code 1
    ARM 链接脚本分析
    Android Bluetooth hci 命令分析
    Android 查看蓝牙hci日志
  • 原文地址:https://www.cnblogs.com/huang-changfan/p/10558851.html
Copyright © 2011-2022 走看看