SQL的复习与总结

检索数据

关键字:

  SELECT  DISTINCT  LIMIT  OFFSET  FROM

  SELECT与FROM用于基础的检索,基本语法为:

    SELECT  column_name,column_name,column_name...column_name FROM  table_name;

  注:默认不排序;sql不区分大小写,但是建议SQL关键字使用大写,本文遵守此规则;建议每个SQL写完后跟上“;”,本文遵守此规则。

  检索所有列:

SELECT * FROM table_name;

  注:*会默认返回所有列的内容,不建议使用*,因为会检索所有内容造成不必要的性能浪费。

  检索不同值:

SELECT DISTINCT column_name,column_name...column_name FROM table_name;

  注:DISTINCT关键字作用于所有列,既对所有检索的列名都进行排它。

  限制结果:

SELECT column_name FROM table_name LIMIT x;

SELECT column_name FROM table_name LIMIT x OFFSET y;

  注:LIMIT表示检索多少行,OFFSET表示从第几行数据开始(第一行数据的下标为0),x与y都是数字(int)


排序检索数据

关键字:

  ORDER BY

  ORDER BY的基本用法:

SELECT column_name FROM table_name ORDER BY column_name;

  注:数据库本身的查询顺序是无意义的(虽然大部分会按照默认顺序排列,但是随着数据的删除等操作,会导致顺序最终无意义,所以就默认为无意义的)

    子句:由SQL的关键字与对应的数据组成。例如SELECT子句与FROM子句。

    ORDER BY子句的位置应该为SELECT的最后(除正序、倒序关键字外)

    ORDER BY也可以对非选择列(不是SELECT子句检索的列)进行排序。

  进行多个列检索时:

SELECT column_name FROM table_name ORDER BY column1_name, column2_name;

  注:仅当column1_name一致时才会对column2_name进行排序,如果column1_name都是唯一的相当于仅对column1_name排序。

  升降序检索:

SELECT column_name FROM table_name ORDER BY column_name DESC/ASC, column2_name;

  注:降序:DESC  升序:ASC  默认就是升序的。

    升降序关键字仅影响其前面的列。


过滤数据

关键字:

  where

  操作符:=   !=  >=  <=  >  <  BETWEEN(AND)  IS NULL

  仅对单个值过滤

SELECT column_name FROM table_name WHERE column_name OPERATION condition;

  注:condition何时使用引号呢?  仅限限定字符串时才需要使用引号,一般使用单引号即可。

    BETWEEN condition1 AND condition2  在限定范围时,该关键字包含限定的两个条件。


高级数据过滤

关键字:

  WHERE  AND  OR  IN  NOT

  多个限定条件的过滤:

SELECT column_name FROM table_name WHERE () AND/OR ();

  注:()表示限定的条件。

    AND要求两个条件都符合。

    OR要求两者符合其一即可,多数DBMS在OR满足条件1时就不在计算第二个条件了。

    AND与OR会有默认的求值顺序,即AND操作符优于OR操作符,当过滤条件>=3个的时候就要注意操作符顺序了,可以使用()来强制要求顺序,好习惯就是忽略默认顺序,优先使用()。

  IN操作符的用法:

SELECT column_name FROM table_name WHERE column_name IN (condition1, confition2, ..., conditionN);

  IN操作符与OR的作用是相同的,但是具有以下优点:

    1.语法更加直观清晰。

    2.求值顺序更加容易管理。

    3.IN操作符比一组OR操作顺序快。

    4.IN可以包含其他SELECT语句(后面同步)。

  NOT操作符的用法:

SELECT column_name FROM table_name WHERE NOT ();

  NOT仅否定跟在其后的条件。NOT与IN联合使用时会更有优势。


用通配符进行过滤

关键字:

  LIKE  %

概念:

  通配符:用来匹配值得一部分的特殊字符。

  搜索模式:由字面值和通配符或两者组合构成的搜索条件。

  注:使用通配符必须配合LIKE操作符。

  百分号(%)通配符:

SELECT column_name FROM table_name WHERE column_name LIKE 'String%'

  注:上面的语句将检索column_name以String内容开头的数据。

    ‘%String’:  匹配以String内容结尾的数据

    '%String%':  匹配包含String内容的数据

    'String%String'  匹配以String内容开始,以String结尾内容的数据

    %匹配0、1和多个字符。且不能匹配到NULL。

  下划线(_)通配符:

  注:下划线与%的作用相同,但是仅匹配单个字符。

  通配符使用注意事项:

    1.通配符使用要适度。

    2.尽量不要在搜索的开头使用通配符。

    3.注意通配符的位置。


拼接字段与计算字段

拼接字段与计算字段都是将多个列的数据进行组合查询。

关键字:

  Concat(col, ...)  AS  + - * /

SELECT Concat(city_name, '(', country_name, ')') AS city_country FROM area ORDER BY city_name

  注:因为拼接字段拼接后无法被客户端直接引用,所以使用AS关键字(别名,别名尽量与列名不同),方便客户端引用。

SELECT prod_id, quantity, item_price, quantity*item_price AS expanded_price FROM orderItems WHERE order_num = 100

  注:计算字段有四个:+  -  *  /


函数的使用

  由于不同的数据库中对函数的支持不同,所以具体的函数可以再使用的时候去查询,以下以MySQL为准

函数:

  提取字符串的组成:SUBSTRING()

  类型转换:CONVERT()

  当前日期:CURDATE()

  以下为统计函数

  获取某列的平均值:AVG()

  获取某列的行数:COUNT()

  获取某列最大值:MAX()

  获取某列最小值:MIN()

  获取某列值之和:SUM()

注:COUNT(ROW)与COUNT(*) *是会计算库中所有的数据,ROW只会计算有值的数据(会忽略为null)

使用统计时,使用DISTINCT时,会排除不同的值,COUNT(DISTINCT ROW)排除ROW中有相同的值。


分组数据

关键字:

  GROUP BY  HAVING

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 第六章:过滤数据

    表名:products 字段:product_id、product_name、product_price、vend_id(供应商) 1.使用WHERE子句:...

    用户1134788
  • 1.5 sleep()方法

    方法sleep()的作用是在指定的毫秒数内让当前"正在执行的线程"休眠(暂停执行)。这个“正在执行的线程”是指this.currentThread()返回的线程...

    用户1134788
  • 1.4 isAlive()方法

    方法isAlive()是判断当前线程是否处于活动状态。 线程代码: public class TestThread extends Thread{ @O...

    用户1134788
  • sql 语言

    sql 语言 DDL DDL 全称 Data Definition Language,即数据定义语言。 DATABASE 创建数据库 CREATE DATABA...

    静默虚空
  • Python+Selenium 技巧篇-svg标签内元素的xpath定位方式

    这种元素比较特殊,需要通过 name 属性来进行定位。 写法如下: //*[name()="svg"]//*[name()="image"]

    小蓝枣
  • MySQL DDL 操作

    MySQL 常有的数据类型如下 整数类型:bit、bool、tinyint、smallint、mediumint、int、bigint 浮点类型:float...

    Demo_Null
  • TypeScript学习第四篇 - 类与继承

    (1). public 公有。在类里面、子类里面、类外面都可以访问。属性如果不加修饰符,默认就是公有。

    越陌度阡
  • shell学习一变量的定义 原

    用符号$加上变量名如 $name 或${name},{}括号是为了确定变理边界,推荐使用

    用户2603479
  • python string类方法

    py3study
  • MySQL 本科班学习汇总

    简单、

扫码关注云+社区

领取腾讯云代金券