说明:对于一门SQL语言,数据查询是我们非常常用的,也是SQL语言中非常大的一块。本文介绍PostgreSQL使用中的数据查询,如有一张表,内容如下:
简单查询
--- 1.查询某张表的全部数据select*from tb_student;-- 2.查询某张表的指定字段select id, name from tb_student;-- 3.给字段、表取别名查询,as可省略select ts.id as 编号, ts.name as 姓名 from tb_student as ts;
单表指定条件查询
-- 1.查询指定记录,如id = 1select*from tb_student where id =1;-- 2.in查询,如id为1、2、3的记录select*from tb_student where id in(1,2,3);-- 3.between and查询,如生日在1990年1月1日到2月1日之间的记录select*from tb_student where birthdate between'1990-01-01'and'1990-02-01';-- 4.like模糊查询,如姓名以“李”开头的记录select*from tb_student where name like'李%';
其中通配符%为匹配任意个字符,_为匹配一个字符,如
李%
:表示以李开头的记录;%李%
:表示字段中包含李的记录;李_
:表示字段为两个字符,且第一个为李的记录;
单表指定条件复杂查询操作
-- 1.查询空值内容,如生日为空的记录select*from tb_student where birthdate isnull;-- 2.and、or多条件查询,如生日不为空并且姓名为“小何”的记录select*from tb_student where birthdate isnotnulland name ='小何';-- 3.查询结果集排序,其中默认升序,asc可省略,desc表示降序select*from tb_student orderby id;-- 4.查询结果集排序,根据生日进行降序排序,null值排在最后,nulls first表示null值排在最前,默认是nulls lastselect*from tb_student orderby birthdate desc nulls last;-- 5.limit关键字查询,按照成绩降序,取前3名select*from tb_student orderby score desclimit3;-- 6.limit关键字查询,按照id排序,从第3个记录开始,取3条记录select*from tb_student orderby id limit3offset2
注意事项:
- 判断某个字段不为空或为空,不能写成
!= null
或者=null
- order by 可指定多个字段,如order by id, score desc,表示按照id升序排序,id相同按照score降序排序;
limit 3 offset 2
可实现分页功能,传递当前页码,每页显示条数,换成下面这个SQL即可
select*from tb_student limit 每页显示条数 offset(当前页码 -1)* 每页显示条数
多表连接查询
创建一张班级表,学生表里新增一个班级字段,表示该学生所属的班级信息,如下:
(班级表)
(学生表,新增一个班级字段,表示所属班级的id)
-- 1.inner join查询,查交集,两个表中都能匹配上的,即每个学生都有班级的记录select*from tb_student innerjoin tb_class on tb_student.class_id = tb_class.id;-- 2.left join,取左表全部数据与右表匹配,匹配不上的数据右侧补空,即全部的学生记录,学生的班级在班级表中匹配不上的补空select*from tb_student leftjoin tb_class on tb_student.class_id = tb_class.id;-- 3.right join,取右表全部数据与左表匹配,匹配不上的数据左侧补空,即全部的班级记录,班级信息在学生表中匹配不上的补空select*from tb_student rightjoin tb_class on tb_student.class_id = tb_class.id;
inner join 查询结果如下,取学生表和班级表里的交集记录;
left join 查询结果如下,取全部学生表与班级表的记录,匹配不上的班级用null填充;
right join 查询结果如下,取全部班级表与学生表的记录,匹配不上的学生用null填充;
子查询
-- 1.exists查询,查询学生表中在班级表中存在的记录select*from tb_student whereexists(select*from tb_class where tb_student.class_id = tb_class.id);-- 2.in关键字子查询,功能同上select*from tb_student where class_id in(select id from tb_class);-- 3.标量子查询,查询学生表中班级名为“高一(1)班”的记录select*from tb_student where class_id =(select id from tb_class where name ='高一(1)班');
标量子查询,指的是将一个查询的结果作为另一个查询的值来使用;
查询结果集合并
对于多个查询结果集合并,可使用
union all
或
union
,如下:
-- 1.union all合并,结果不去重,速度快select*from tb_student where class_id in(1,2)unionallselect*from tb_student where birthdate isnotnull;-- 2.union 合并,结果去重,速度慢select*from tb_student where class_id in(1,2)unionselect*from tb_student where birthdate isnotnull;
union all查询结果,有重复数据:
union查询结果,无重复数据:
需要注意,合并的结果集字段数量需要相等,如果不一样多,可以在字段少的那边加上null字段,使其相等。如下,我在两张表左右各自新增一个null字段:
总结
本文介绍了PostgreSQL使用中的数据查询,参考下面视频:
- 一天学完 PostgreSQL
版权归原作者 何中应 所有, 如有侵权,请联系我们删除。