SQL 学习记录

前段时间看了,发现效果不大,这次还是写成正式的笔记好了!下面写的例子都是在 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 学习记录)