前段时间看了,发现效果不大,这次还是写成正式的笔记好了!下面写的例子都是在 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 命令的末端最好使用分号结尾。
- 字符串都用单引号,大部分数据库也是接受双引号的。