数据库3复杂查询

 

简单查询:

 

一、投影

select * from 表名

select 列1,列2... from 表名

select distinct 列名 from 表名

 

二、筛选

select top 数字 列|* from 表名

(一)等值与不等值

select * from 表名 where 列名=值

select * from 表名 where 列名!=值

select * from 表名 where 列名>值

select * from 表名 where 列名<值

select * from 表名 where 列名>=值

select * from 表名 where 列名<=值

 

(二)多条件与范围

select * from 表名 where 条件1 and|or 条件2 ...

select * from 表名 where between ... and ...

select * from 表名 where 列 in (值列表)

(三)模糊查询 like % _

 

select * from 表名 where 列 like '%_....'

 

 

三、排序

select * from 表名 where 条件 order by 列名 ASC|DESC,列名 ASC|DESC

 

 

四、分组:

统计函数(聚合函数)

count(), max(), min(), sum(), avg()

count()统计总行数

count(*)得到所有的行数

count(列)得到该列中所有非null个数。

select COUNT(*) from car where Brand='b003'

max(列) 这一列的最大,min(列)这一列的最小

select min(price) from car

sum(列)这一列的和,avg(列)这一列的平均

select AVG(price) from car

group by ...having...

 

1.group by后面跟的是列名。

 

2.一旦使用group by分组了,则select和from中间就不能用*,只能包含两类东西一类是:group by 后面的列名,另一类是统计函数

select Oil,avg(price) from Car group by oil

对于统计函数生成的列,默认是无列名,可以通过下面的方法指定列名。

select Oil as 油耗,COUNT(*) as 数量,avg(price) 均价 from Car group by oil

having后面一般跟得是统计函数。它用来对分组后的数据进一步筛选。

复杂查询:

 

一、连接查询

 

把多个表的列合在一个界面视图中。

思想:1.生成笛卡尔积。2.对笛卡尔积进行筛选。3.选择列进行显示。

select 表1.列1,表1.列2,表2.列1,表2.列2…… from 表1,表2 where 表1.列=表2.列

select * from 表1

join 表2 on 表1.列=表2.列

join 表3 on 表2.列=表3.列

左连(left join),右连(right join),全连(full join)

 

二、联合查询

把多个表的行合在一个界面视图中。

用union把两个查询组合在一起。要求是这两个查询的列要一一对应。

 

三、子查询(嵌套查询)

 

(一)无关子查询:

至少是两层查询,在外层查询的里面再写查询。

里层查询为外层查询提供查询的中间内容。

(二)相关子查询:

posted @ 2015-03-02 19:32  奔跑的小黄鸡  阅读(360)  评论(0编辑  收藏  举报