SQL语句复习整理

SQL语句
  SQL 是用于访问和处理数据库的标准的计算机语言,SQL 指结构化查询语言

  可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL)。

SQL (结构化查询语言)是用于执行查询的语法。但是 SQL 语言也包含用于更新、插入和删除记录的语法。

查询和更新指令构成了 SQL 的 DML 部分:

SELECT - 从数据库表中获取数据
UPDATE - 更新数据库表中的数据
DELETE - 从数据库表中删除数据
INSERT INTO - 向数据库表中插入数据
SQL 的数据定义语言 (DDL) 部分使我们有能力创建或删除表格。我们也可以定义索引(键),规定表之间的链接,以及施加表间的约束。

SQL 中最重要的 DDL 语句:

CREATE DATABASE - 创建新数据库
ALTER DATABASE - 修改数据库
CREATE TABLE - 创建新表
ALTER TABLE - 变更(改变)数据库表
DROP TABLE - 删除表
CREATE INDEX - 创建索引(搜索键)
DROP INDEX - 删除索引
(该部分转自https://www.w3school.com.cn/sql/sql_syntax.asp)

  

SQL基础语句  

  SELECT 列名称 FROM 表名称

  SELECT DISTINCT 列名称 FROM 表名称 (DISTINCT 用于返回唯一不同的值)

  SELECT 列名称 FROM 表名称 WHERE 列 运算符 值

  SELECT 列名称 FROM 表名称 ORDER BY 列名称 (ORDER BY 语句用于对结果集进行排序。按照降序对记录进行排序,可以使用 DESC 关键字。)

  INSERT INTO 表名称 VALUES (值1, 值2,....) 向表格中插入新的行。

  INSERT INTO table_name (列1, 列2,...) VALUES (值1, 值2,....) 指定所要插入数据的列

  UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值 (修改表中的数据。)

  DELETE FROM 表名称 WHERE 列名称 = 值 (DELETE 语句用于删除表中的行。)

SQL高级语句

  TOP 子句用于规定从表的顶部开始要返回的记录的数目。可以规定个数也可以根据百分比规定

  LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。

    SELECT column_name(s)
    FROM table_name
    WHERE column_name (NOT) LIKE pattern

  通配符:

    

  IN操作符

    IN 操作符允许我们在 WHERE 子句中规定多个值。    

    SELECT column_name(s)
    FROM table_name
    WHERE column_name IN (value1,value2,...)

  BETWEEN操作符

    BETWEEN 操作符在 WHERE 子句中使用,作用是选取介于两个值之间的数据范围。   

    SELECT column_name(s)
    FROM table_name
    WHERE column_name
    BETWEEN value1 AND value2

  SQL Alias 别名

    通过使用 SQL,可以为列名称和表名称指定别名(Alias)。

    

   

   SQL JOIN

    SQL join用于根据两个或者多个表中的列之间的关系,从这些表中查询数据

    

      JOIN: 如果表中有至少一个匹配,则返回行
      LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行
      RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行
      FULL JOIN: 只要其中一个表中存在匹配,就返回行

  

    SELECT column_name(s)
    FROM table_name1
    INNER JOIN table_name2
    ON table_name1.column_name=table_name2.column_name

  SQL UNION

    UNION 操作符用于合并两个或多个 SELECT 语句的结果集。

    请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。注释:默认地,UNION 操作符选取不同的值。如果允许重复的值,请使用 UNION ALL。

      SELECT column_name(s) FROM table_name1
      UNION
      SELECT column_name(s) FROM table_name2

      SELECT column_name(s) FROM table_name1
      UNION ALL
      SELECT column_name(s) FROM table_name2

  SQL SELECT INTO

    SQL SELECT INTO 语句可用于创建表的备份复件。

      SELECT *
      INTO new_table_name [IN externaldatabase]   
      FROM old_tablename

      SELECT column_name(s)
      INTO new_table_name [IN externaldatabase]
      FROM old_tablename

  SQL CREATE DATABASE

    CREATE DATABASE 用于创建数据库。

    CREATE DATABASE database_name

  SQL CREATE TABLE    

    CREATE TABLE 表名称
    (
    列名称1 数据类型,
    列名称2 数据类型,
    列名称3 数据类型,
    ....
    )

    

   SQL 约束   

    NOT NULL  约束强制列不接受 NULL 值。NOT NULL 约束强制字段始终包含值。这意味着,如果不向字段添加值,就无法插入新记录或者更新记录。

    UNIQUE  约束唯一标识数据库表中的每条记录。UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。PRIMARY KEY 拥有自动定义的 UNIQUE 约束。请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。

    PRIMARY KEY  约束唯一标识数据库表中的每条记录。主键必须包含唯一的值。主键列不能包含 NULL 值。每个表都应该有一个主键,并且每个表只能有一个主键。

    FOREIGN KEY  一个表中的 FOREIGN KEY 指向另一个表中的 PRIMARY KEY。

    CHECK  CHECK 约束用于限制列中的值的范围。如果对单个列定义 CHECK 约束,那么该列只允许特定的值。如果对一个表定义 CHECK 约束,那么此约束会在特定的列中对值进行限制。

    DEFAULT  约束用于向列中插入默认值。如果没有规定其他的值,那么会将默认值添加到所有的新记录。

  SQL CREATE INDEX

    CREATE INDEX 语句用于在表中创建索引。在不读取整个表的情况下,索引使数据库应用程序可以更快地查找数据。

  SQL DROP

    通过使用 DROP 语句,可以轻松地删除索引、表和数据库。

    我们可以使用 DROP INDEX 命令删除表格中的索引。

    DROP TABLE 语句用于删除表(表的结构、属性以及索引也会被删除):DROP TABLE 表名称

    DROP DATABASE 语句用于删除数据库:DROP DATABASE 数据库名称  

    TRUNCATE TABLE 语句仅仅除去表内的数据,但并不删除表本身:TRUNCATE TABLE 表名称

  SQL ALTER TABLE 语句

    ALTER TABLE 语句用于在已有的表中添加、修改或删除列。

    在表中添加列:

      ALTER TABLE table_name
      ADD column_name datatype

    删除表中的列:  

      ALTER TABLE table_name
      DROP COLUMN column_name

    改变表中的数据类型     

      ALTER TABLE table_name
      ALTER COLUMN column_name datatype

  SQL AUTO INCREMENT

    Auto-increment 会在新记录插入表中时生成一个唯一的数字。

  SQL VIEW

    视图是可视化的表。

  SQL Date

    不同的数据库中都有关于Date的内建函数,也有不同的Date数据类型,需要具体情况具体分析

  SQL NULL值

    NULL 值是遗漏的未知数据。默认地,表的列可以存放 NULL 值。

    如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新记录或更新已有的记录。这意味着该字段将以 NULL 值保存。NULL 值的处理方式与其他值不同。NULL 用作未知的或不适用的值的占位符。  

    如何测试 NULL 值呢?

    无法使用比较运算符来测试 NULL 值,比如 =, <, 或者 <>。我们必须使用 IS NULL 和 IS NOT NULL 操作符。

    SQL ISNULL():  如果有字段的值是 NULL,我们希望 NULL 值为 0,如果该字段是 NULL,则不利于计算,因此如果值是 NULL 则 ISNULL() 返回 0。

面试题:

1.查询中用到的关键词主要包含六个,并且他们的顺序依次为 select--from--where--groupby--having--orderby
其中select和from是必须的,其他关键词是可选的,这六个关键词的执行顺序 与sql语句的书写顺序并不是一样的,而是按照下面的顺序来执行
from:需要从哪个数据表检索数据
where:过滤表中数据的条件
group by:如何将上面过滤出的数据分组
having:对上面已经分组的数据进行过滤的条件
select:查看结果集中的哪个列,或列的计算结果
order by :按照什么样的顺序来查看返回的数据
原文地址:https://www.cnblogs.com/AICROC/p/13841029.html