1.新增表数据
INSERT INTO [TABLE_NAME] (column1, column2, column3,...columnN) VALUES (value1, value2, value3,...valueN);
例:insert into person(id,name,age,phone,address) values (1,'yang',22,'123232323','中国上海');
2.删除表数据
DELETE FROM [table_name] WHERE [condition];
例:delete from person where id = 1;
3.修改表数据
UPDATE [table_name] SET column1 = value1, column2 = value2....WHERE [condition];
例:update person set address='浙江杭州' where id = 1;
4.查询表数据
Where语句,用于筛选查询出来的数据集,指定的条件语句中可以使用基本的算术、关系和逻辑运算,例如:>,<,=,!=,&&,||。
例: 查询年龄为22的年轻人
select * from person where name='yang'&& age=22;
LIKE 子句,一般用来做一些简单的搜索查询,或者说模糊匹配,表达式主要涉及到两个符号:百分号 %:匹配任意多个字符,下划线 _:匹配固定一个字符。
例:查询所有的数据,找到其中 name 字段以字符「ang」结尾的数据记录集合:
select * from person where name like '%ang';
查询所有的数据,找到其中 name 字段以字符「ang」结尾,并且前面还有一个任意字符的数据记录集合:
select * from person where name like '_ang';
select * from person where age in (22,30,23);
你也可以使用 not in 反向限制,例如这个 SQL 则可以查出所有年龄不是这三个值的数据记录信息。
select * from person where age not in (22,30,23);
ORDER BY 子句,根据一列或者多列的值,按照升序或者降序排列数据。某些数据库就默认以升序排列查询结果。
基本的 SQL 语法为:
SELECT column FROM table_name [WHERE condition]
[ORDER BY column1, column2, .. columnN] [ASC | DESC];
ASC 表示数据结果集按升序排序,DESC 表示数据结果集按降序排序。一般来说,我们按某一列进行排序即可,当然,有时候一列排序并不能完全解决问题,如果按多列排序,那么当遇到某一列值相同的时候,就会参照第二个列参数将这些重复列值得数据记录再一次排序。
举个例子:我们将 person 表中的数据参照 id 列,倒序排序:
select * from person order by id desc;
GROUP BY 子句,用于将查询返回的结果集进行一个分组,并展示各个分组中排在第一个的记录,将分组中其余成员隐藏。
我们按照姓名对结果集进行分组,SQL 如下:
select * from person group by name;
执行 SQL,得到结果。分组之后,只展示每个分组下排序第一的记录,其余成员隐藏。如果你没有显式执行排序方式的话,将默认以你用于分组参照的那个字段进行排序。当然,我们是可以执行排序方式的,使用 order by 子句:
select * from person group by name order by id;
比如我们计算每个分组下的平均年龄:
select avg(age) as '平均年龄' from person group by name;
HAVING 子句,HAVING 子句就是一个高配版的 where 子句,无论是我们的分组或是排序,都是基于以返回的结果集,也就是说 where 子句的筛选已经结束。如果我们对排序、分组后的数据集依然有筛选需求,就用到我们的 HAVING 子句了。
例如:
select avg(age) as vage from person group by name having vage>23;
分组之后,我们得到每个分组中数据的平均年龄,再者我们通过 having 语句筛选出平均年龄大于 23 的数据记录。
优先级
SELECT column1, column2
FROM table
WHERE [ conditions ]
GROUP BY column1, column2
HAVING [ conditions ]
ORDER BY column1, column2