SQL 常用语句
一、SELECT 语句
SELECT 语句用于从数据库中选取数据,结果被存储在一个结果表中,称为结果集。
1、查询某个表所有数据
SELECT * FROM table_name;
2、查询某个表指定列的所有数据
SELECT column_name,column_name
FROM table_name;
3、DISTINCT 对查询结果去重
SELECT DISTINCT column_name,column_name
FROM table_name;
4、WHERE 条件查询
SELECT column_name,column_name
FROM table_name
WHERE column_name operator value;
operator 运算符 | 描述 |
---|---|
= | 等于 |
<> | 不等于。在 SQL 的一些版本中,可被写成 != |
> | 大于 |
< | 小于 |
>= | 大于等于 |
<= | 小于等于 |
BETWEEN | 在某个范围内 |
LIKE | 搜索某种模式 |
IN | 指定针对某个列的多个可能值 |
- SELECT * FROM table_name WHERE column_name=value;
- SELECT * FROM table_name WHERE column_name BETWEEN value1 AND value2;
- SELECT * FROM table_name WHERE column_name IN (value1,value2...);
- SELECT * FROM table_name WHERE column_name LIKE pattern;
LIKE 模糊查询支持通配符(百分号 % 匹配 0 到 N 个任意字符,下划线_匹配 1 个任意字符),如果没有通配符则相当于等于 = 运算符
5、组合条件查询 AND、OR
AND 会返回同时满足两个条件的记录,OR 则只需要一个条件满足。另外多个 AND 和 OR 可以组合使用,使用小括号来提升优先级。
SELECT * FROM table1
WHERE column1 operator value1
AND (column2 operator value2 OR column3 operator value3);
6、结果排序 ORDER BY
ORDER BY 语句用于根据指定的列对结果集进行排序。可以指定多个列,如果是多个列,优先按照先指定的列排序。默认是升序 ASC,逆序需要使用 DESC 关键字。
SELECT column_name,column_name
FROM table_name
ORDER BY column_name ASC|DESC;
7、获取指定条数的记录 LIMIT
从第一条开始获取 number 数量的数据
SELECT column_name
FROM table_name
LIMIT number;
从第 index(不包括)条开始获取 number 数量的数据
SELECT column_name
FROM table_name
LIMIT number OFFSET index ;
二、INERT INTO 语句
INSERT INTO 语句用于向表中插入新记录。
没有指定要插入数据的列名
INSERT INTO table_name
VALUES (value1,value2,value3,...);
指定要插入数据的列名
INSERT INTO table_name (column1,column2,column3,...)
VALUES (value1,value2,value3,...);
没有指定要插入数据的列名的形式需要列出插入行的每一列数据。
三、UPDATE 语句
UPDATE 语句用于更新表中的记录。可以使用 WHERE 子句规定哪些记录需要更新。如果省略了 WHERE 子句,所有的记录都将被更新!
UPDATE table_name
SET column1=value1,column2=value2,...
WHERE some_column=some_value;
执行没有 WHERE 子句的 UPDATE 要慎重,再慎重。
四、DELETE 语句
DELETE 语句用于删除表中的记录。可以使用 WHERE 子句规定哪些记录需要删除。如果省略了 WHERE 子句,所有的记录都将被删除!
DELETE FROM table_name
WHERE some_column=some_value;
在删除记录时要格外小心
五、NULL 值
NULL 值代表遗漏的未知数据。默认地,表的列可以存放 NULL 值。NULL 值的处理方式与其他值不同。使用 IS NULL 或者 IS NOT NULL 处理 NULL 值。另外如果指定条件列有 NULL 值,查询时不对 NULL 值特别对待将会忽略 NULL 行。
SELECT column_name,column_name
FROM table_name
WHERE column_name IS NULL;