SELECT
简介
- SELECT 语句用于从数据库中选取数据。
- 结果被存储在一个结果表中,称为结果集。
语法
SELECT column_name,column_name
FROM table_name;
实例
SELECT name,country FROM Store;
SELECT DISTINCT
简介
- 在表中,一个列可能会包含多个重复值,有时也许希望仅仅列出不同(distinct)的值。
- DISTINCT 关键词用于返回唯一不同的值。
语法
SELECT DISTINCT column_name,column_name
FROM table_name;
WHERE
- WHERE 子句用于过滤记录。
- 用于提取满足指定条件的记录。
语法
SELECT column_name,column_name
FROM table_name
WHERE column_name operator value;
实例
SELECT * FROM Store WHERE country='China';
SQL 中的opreator运算符
运算符 | 含义 |
---|---|
= | 等于 |
<> or != | 不等于 |
> | 大于 |
< | 等于 |
>= | 大于等于 |
<= | 小于等于 |
is null | 空值 |
BETWEEN | 在某个范围内 |
LIKE | 搜索某种模式 |
IN | 指定针对某个列的多个可能值 |
examples:
Select * from emp where comm is null;
Select * from emp where sal between 1500 and 3000;
Select * from emp where sal in (5000,3000,1500);
Select * from emp where ename like 'M%';
查询 EMP 表中 Ename 列中有 M 的值,M 为要查询内容中的模糊信息。
% 表示多个字值,_ 下划线表示一个字符;
M% : 为能配符,正则表达式,表示的意思为模糊查询信息为 M 开头的。
%M% : 表示查询包含M的所有内容。
%M_ : 表示查询以M在倒数第二位的所有内容。
补充
- SQL 使用单引号来环绕文本值。
- 如果是数值字段,不能使用引号。
AND 和 OR 运算符
简介
AND 和 OR 运算符用于基于一个以上条件对记录进行过滤。
AND
如果第一个条件和第二个条件都成立,则 AND 运算符显示一条记录。
OR 运算符
如果第一个条件和第二个条件中只要有一个成立,则 OR 运算符显示一条记录。
实例
只用AND:
SELECT * FROM Store
WHERE country='China'
AND price > 50;
只用OR:
SELECT * FROM Store
WHERE country='China'
OR country='Serbia';
混合使用AND和OR:
SELECT * FROM Store
WHERE price > 15
AND (country='China' OR country='Serbia');
ORDER BY
简介
用于对结果集按照一个列或者多个列进行排序。
默认按照升序,使用DESC关键词可以实现降序。
语法
SELECT column_name,column_name
FROM table_name
ORDER BY column_name1, column_name2 ASC|DESC;
按照多个列名的顺序来一步步进行排序,如上述例子中,先按照column _ name1进行排序得到若干小组,然后在这些小组中按照column _ name2进行排序。得到最终的结果
INSERT INTO
简介
用于向表中插入记录
语法
1.不指定要插入数据的列名,只需提供被插入的值即可,此时需要列出新一行的每一列数据:
INSERT INTO table_name
VALUES (value1,value2,value3,...);
2.指定列名及被插入的值:
INSERT INTO table_name (column1,column2,column3,...)
VALUES (value1,value2,value3,...);
实例
INSERT INTO Store (name, url, price, country)
VALUES ('RY','https://www.baidu.com/','520','China');
UPDATE
简介
用于更新表中已经存在的记录
语法
UPDATE table_name
SET column1 = value1, column2 = value2,……
WHERE some_column_name = some_concrete_value;
实例
UPDATE Store
SET price='500', country='CHINA'
WHERE name='拓展坞';
补充
慎重执行没有 WHERE 子句的 UPDATE,不然很肯将表中所有数据都按照SET(或其他关键词)的内容给修改掉。
DELETE
简介
用于删除表中的行(记录)
语法
DELETE FROM table_name
WHERE some_column_name = some_concrete_value;
实例
DELETE FROM Store
WHERE name='笔记本' AND price='4999';
补充
管理员可以在不删除表的情况下,删除表中所有的行。这意味着表结构、属性、索引将保持不变:
DELETE FROM table_name;
或者
DELETE * FROM table_name;
但是在删除记录时要小心,因为无法撤销操作。