美文网首页
SQL 学习记录

SQL 学习记录

作者: BGING | 来源:发表于2017-12-25 10:04 被阅读0次

    前段时间看了,发现效果不大,这次还是写成正式的笔记好了!下面写的例子都是在 MySQL 验证过。Oracle部分例子没有

    [TOC]

    SQL DML 和 DDL

    1、SQL 的 DML 部分:于更新、插入和删除记录的语法。

    • SELECT - 从数据库表中获取数据

    • UPDATE - 更新数据库表中的数据

    • DELETE - 从数据库表中删除数据

    • INSERT INTO - 向数据库表中插入数据

    2、SQL 中最重要的 DDL 语句:部分使我们有能力创建或删除表格。我们也可以定义索引(键),规定表之间的链接,以及施加表间的约束

    • CREATE DATABASE - 创建新数据库
    • ALTER DATABASE - 修改数据库
    • CREATE TABLE - 创建新表
    • ALTER TABLE - 变更(改变)数据库表
    • DROP TABLE - 删除表
    • CREATE INDEX - 创建索引(搜索键)
    • DROP INDEX - 删除索引
    SELECT 查询语句

    select 列名 from 表名

    select * from 表名

    SELECT DISTINCT : SELECT DISTINCT 列名 FROM 表名

    排除重复数据

    SELECT DISTINCT 列名 from 表名
    
    WHERE 语句: ... WHERE ...

    在 WHERE 语句后面常用的操作符

    =
    <> 不等于
    >
    <
    >=
    <=
    BETWEEN 在某个值范围内
    LIKE 模糊匹配搜索
    AND 两个条件都成立 ... WHERE FirstName='Thomas' AND LastName='Carter'
    OR 其中一个条件成立 ... WHERE FirstName='Thomas' OR LastName='Carter'

    注解: 有的 SQL 版本不等于 <> 可以写成 !=

    ORDER BY : ... WHERE ORDER BY DESC

    对结果集进行排序

    • 这必须是查询好后能返回一个结果,所以 ORDER BY 一般是放在查询语句最后。
    • 默认是ASC/升序 , DESC /降序
    SELECT Company, OrderNumber FROM Orders ORDER BY Company DESC
    
    INSERT INTO : INSERT INTO 表名 VALUES ( VALUE1, VALUE2...)
    -- 默认全部插入
    INSERT INTO 表名称 VALUES (值1, 值2,....)  -- 注意插入值的顺序和创建表列的顺序一致
    
    -- 指定行列插入
    INSERT INTO Persons (LastName, Address) VALUES ('Wilson', 'Champs-Elysees')
    
    UPDATE : UPDATE 表名 SET 列名 = 新值 WHERE ...
    UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值
    
    DELETE : DELETE FROM 表名 WHERE ...
    DELETE FROM 表名称 WHERE 列名称 = 值
    
    -- 删除所有的行
    DELETE FROM table_name
    DELETE * FROM table_name
    
    
    
    TOP 子句:限制返回条数,实现分页功能
    • MySQL 语法

      -- 列是从 0 开始计算的
      SELECT *
      FROM Persons
      LIMIT 0,5;
      
      -- 从第一列开始共返回5列数据
      SELECT *
      FROM Persons
      LIMIT 5;
      
      -- SQL 中的 LIMIT 语句前面是不需要加 WHERE 语句的。
      
    • Oracle

      SELECT column_name(s)
      FROM table_name
      WHERE ROWNUM <= number
      
      SELECT *
      FROM Persons
      WHERE ROWNUM <= 5
      
      -- ROWNUM 是没有 >= 的因此在做分页查询的时候会用 2 层 SELECT 查询语句
      
    SQL LIKE : ... WHERE 列名 LIKE ''

    实现模糊查询功能

    SELECT column_name(s)
    FROM table_name
    WHERE column_name LIKE pattern
    
    -- % 通配符的使用
    
    -- % 可以理解为占位符 0 个或多个位置,以 "宝" 结尾的列都能查询出来
    SELECT * FROM websites  WHERE NAME LIKE '%宝';
    
    -- 包含
    SELECT * FROM websites  WHERE NAME LIKE '%宝%';
    
    -- 不包含
    SELECT * FROM websites  WHERE NAME NOT LIKE '%宝%';
    
    -- _ 只能代替一个字符的位置所以可以搜索出 2 个长度并且是以“宝”结尾的列
    SELECT * FROM websites  WHERE NAME LIKE '_宝';
    
    -- 
    
    SQL 通配符
    字符 说明 例子 MySQL
    % 代替一个或多个字符 yes
    _ 仅代替一个字符 yes
    [charlist] 字符中任何一个单一的字符 ... WHERE country LIKE '[C]%'; no
    [^charlist] or [! charlist] 不在字符列中任何一个单一的字符 ... WHERE country LIKE '[!N]%'; no

    表格中标注 no 的是我在MySQL里没有验证出结果

    SQL IN : ... WHERE 列名 IN (value1,value2,...)
    SELECT column_name(s)
    FROM table_name
    WHERE column_name IN (value1,value2,...)
    
    SQL BETWEEN : WHERE 列名 BETWEEN value1 AND value2
    SELECT column_name(s)
    FROM table_name
    WHERE column_name
    BETWEEN value1 AND value2
    
    SQL Alias(AS): 别名
    SELECT LastName AS Family, FirstName AS Name
    FROM Persons
    
    -- 其实也是可以不用写 AS 直接用空格代替
    
    SELECT LastName  Family, FirstName  Name
    FROM Persons
    
    

    注意事项

    • SQL 对大小写不敏感。
    • SQL 命令的末端最好使用分号结尾。
    • 字符串都用单引号,大部分数据库也是接受双引号的。

    相关文章

      网友评论

          本文标题:SQL 学习记录

          本文链接:https://www.haomeiwen.com/subject/qkokgxtx.html