SQL 常用语句

admin
admin 2019年10月16日
  • 在其它设备中阅读本文章

一、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;