(一)SQL关联查询的使用技巧 (各种 join)

---恢复内容开始---

(一)SQL关联查询的使用技巧 (各种 join)

这几天因为工作的时候,发现自己的sql语句基础不是很好,特意研究了一下,发现sql语句真的是博大精深,sql语句不仅是要查出来你想要的数据,更讲究查询的效率,因为在查询大量数据时往往会因为数据量大,造成效率很低,再加上前后台数据的交互,造成了访问延迟等等的一系列问题。

在我们的日常工作中往往用到很多的查询方式,例如 嵌套查询,关联查询,子查询等等,就我而言,我感觉关联查询是最容易学习,和效率最高的。下面就我总结的关联查询如下:

关联查询:

1)内连接

关联查询分为内连接(inner join或者join)只返回两个表中连接字段相等的行
select * from 表1 inner join 表2
on 表1.字段号=表2.字段号
内连接连接三表的例子:
select * from (表1 inner join 表2
on 表1.字段号=表2.字段号) inner join 表3
on
表1.字段号=表3.字段号
内连接四表的例子:
select * from ((表1 inner join 表2
on 表1.字段号=表2.字段号)inner join 表3
on
表1.字段号=表3.字段号)inner join 表4
on 表1.字段号=表4.字段号
类似查询最好使用数字字段,其查询的字段必须是主键,自动增长类型。否则很难成功,内连接还可以增加where字句来缩小乏味

2)左连接

左连接(left join)返回左表中所有记录和右表中连接字段相等的记录
如果两个表中字段并不完全一一对应,想要那些没有对应的字段也显示出来就可以使用左连接和
右连接查询,一个是包括左边所有,一个是包括右边所有罢了
左连接两表的例子:
select * from 表1 left join 表2
on 表.字段号=表2.字段号;
左连接三表查询的例子:
left join 表2 on 表1.字段号=表2.字段号 left join 表3 on
表2.字段号=表3.字段号

3)右连接

右连接(right join)返回右表中所有记录和左表中连接字段相等的记录,语法与左连接同,这里就不再举例。另外还有全连接,是将左右两表中没有相关性的记录都选出来。
自连接左连接右连接还可以用于同一张表中,称为自连接,这中用法一般用于表中有层级关系的数据,例如部门表,有部门id,部门名称,上级部门id。为了查询部门名称和
所有上级部门名称,可以这样查询
select 部门名,上级部门名 from 部门表 别名1
left join 部门表 别名2
on 别名1.部门id=别名2.上级部门id

4)分组查询

group by的使用技巧:他的作用就是对相应的字段进行分组:

例子如下:

新建一张学生成绩数据表:

这是一个t_grade表

(1)查询该学生的总体成绩的总分

sql:  select
t.stuName,SUM(t.score) as score from t_grade t 
GROUP BY t.stuName

结果图:

(2)查询该学生最高的成绩

sql: select
t.stuName,MAX(t.score) as score from t_grade t 
GROUP BY t.stuName
结果图:

在分组查询中往往还有很多的查询关系,这里我就不一一的例举了

下面分享一个工作中用到的五张表关联查询所用到的sql语句

下面是所有的表:

(1)sam_domain

(2) sam_appsystem

(3) sam_service

(4) sam_operation

(5) nxgjj_user_operation

查询需求:查询出每个系统模块下,有多少用户访问生成柱状图:

sql :

select
total.app_name, count(distinct total.userid) total_num from

(

select
t.domain_code,a.app_code,a.app_name,s.service_code,o.operation_code,u.* from

(

select
domain.domain_code from sam_domain domain

where domain.domain_code =‘com.hopesoftnxgjj‘

) t

inner
join sam_appsystem a on a.domain_code = t.domain_code

left join 
sam_service s on s.app_code = a.app_code

left join sam_operation o on
o.sam_service_code = s.service_code

left join nxgjj_user_operation u on
u.dest_operation_code = o.operation_code) total

group by total.app_name

结果图:

效果图:

以上数据都为测试数据;

---恢复内容结束---

(一)SQL关联查询的使用技巧 (各种 join)

这几天因为工作的时候,发现自己的sql语句基础不是很好,特意研究了一下,发现sql语句真的是博大精深,sql语句不仅是要查出来你想要的数据,更讲究查询的效率,因为在查询大量数据时往往会因为数据量大,造成效率很低,再加上前后台数据的交互,造成了访问延迟等等的一系列问题。

在我们的日常工作中往往用到很多的查询方式,例如 嵌套查询,关联查询,子查询等等,就我而言,我感觉关联查询是最容易学习,和效率最高的。下面就我总结的关联查询如下:

关联查询:

1)内连接

关联查询分为内连接(inner join或者join)只返回两个表中连接字段相等的行
select * from 表1 inner join 表2
on 表1.字段号=表2.字段号
内连接连接三表的例子:
select * from (表1 inner join 表2
on 表1.字段号=表2.字段号) inner join 表3
on
表1.字段号=表3.字段号
内连接四表的例子:
select * from ((表1 inner join 表2
on 表1.字段号=表2.字段号)inner join 表3
on
表1.字段号=表3.字段号)inner join 表4
on 表1.字段号=表4.字段号
类似查询最好使用数字字段,其查询的字段必须是主键,自动增长类型。否则很难成功,内连接还可以增加where字句来缩小乏味

2)左连接

左连接(left join)返回左表中所有记录和右表中连接字段相等的记录
如果两个表中字段并不完全一一对应,想要那些没有对应的字段也显示出来就可以使用左连接和
右连接查询,一个是包括左边所有,一个是包括右边所有罢了
左连接两表的例子:
select * from 表1 left join 表2
on 表.字段号=表2.字段号;
左连接三表查询的例子:
left join 表2 on 表1.字段号=表2.字段号 left join 表3 on
表2.字段号=表3.字段号

3)右连接

右连接(right join)返回右表中所有记录和左表中连接字段相等的记录,语法与左连接同,这里就不再举例。另外还有全连接,是将左右两表中没有相关性的记录都选出来。
自连接左连接右连接还可以用于同一张表中,称为自连接,这中用法一般用于表中有层级关系的数据,例如部门表,有部门id,部门名称,上级部门id。为了查询部门名称和
所有上级部门名称,可以这样查询
select 部门名,上级部门名 from 部门表 别名1
left join 部门表 别名2
on 别名1.部门id=别名2.上级部门id

4)分组查询

group by的使用技巧:他的作用就是对相应的字段进行分组:

例子如下:

新建一张学生成绩数据表:

这是一个t_grade表

(1)查询该学生的总体成绩的总分

sql:  select
t.stuName,SUM(t.score) as score from t_grade t 
GROUP BY t.stuName

结果图:

(2)查询该学生最高的成绩

sql: select
t.stuName,MAX(t.score) as score from t_grade t 
GROUP BY t.stuName
结果图:

在分组查询中往往还有很多的查询关系,这里我就不一一的例举了

下面分享一个工作中用到的五张表关联查询所用到的sql语句

下面是所有的表:

(1)sam_domain

(2) sam_appsystem

(3) sam_service

(4) sam_operation

(5) nxgjj_user_operation

查询需求:查询出每个系统模块下,有多少用户访问生成柱状图:

sql :

select
total.app_name, count(distinct total.userid) total_num from

(

select
t.domain_code,a.app_code,a.app_name,s.service_code,o.operation_code,u.* from

(

select
domain.domain_code from sam_domain domain

where domain.domain_code =‘com.hopesoftnxgjj‘

) t

inner
join sam_appsystem a on a.domain_code = t.domain_code

left join 
sam_service s on s.app_code = a.app_code

left join sam_operation o on
o.sam_service_code = s.service_code

left join nxgjj_user_operation u on
u.dest_operation_code = o.operation_code) total

group by total.app_name

结果图:

效果图:

以上数据都为测试数据;

时间: 2024-10-16 13:03:08

(一)SQL关联查询的使用技巧 (各种 join)的相关文章

通过Spark SQL关联查询两个HDFS上的文件操作

order_created.txt   订单编号  订单创建时间 10703007267488 2014-05-01 06:01:12.334+01 10101043505096 2014-05-01 07:28:12.342+01 10103043509747 2014-05-01 07:50:12.33+01 10103043501575 2014-05-01 09:27:12.33+01 10104043514061 2014-05-01 09:03:12.324+01 order_pic

sql关联查询使用别名报错

我有两个关联表: student{ id, class_id, name, age, comment } class{ id, name, grade, comment } 现在执行以下sql: select s.id as id, s.name as name, s.age.as age, c.grade as grade from student s join class c on s.class_id = c.id; 报错 java.sql.SQLException: Column 'ag

sql关联查询样例

两张表联合查询,显示需要的信息 SELECT b.`NAME`,a.`USER_ID`,a.numFROM (select `USER_ID`,count(*) AS num from af_person_deposit_detail_mem group by `USER_ID`) a LEFT JOIN base_pc_user_info b on a.`USER_ID` = b.`USER_ID`;

SQL关联查询 直接join 和子查询的区别

SQL语句执行的时候是有一定顺序的. 1.from先选择一个表,构成一个结果集. 2.where对结果集进行筛选,筛选出需要的信息形成新的结果集. 3.group by对新的结果集分组. 4.having筛选出想要的分组. 5.select选择列. 6.order by当所有的条件都弄完了.最后排序. explain select users.`mobile_num`, concat(users.`lastName` ,users.`firstName`) as userName, users.

SQL关联查询总结

employee表: department表: 笛卡儿积:

MySQL 关联查询  外连接 { LEFT| RIGHT } JOIN

左外连接: (以左表为基准)两张表做连接的时候,在连接条件不匹配的时候留下左表中的数据,而右表中的数据以NULL填充例:使用左连接把学生的数据全取出来,该学生没有学院信息的用NULL填充 mysql>  select * from  student  left join  department         ->  on dept_id= d_id; 右外连接: (以右表为基准)对两张表做连接的时候,在连接条件不匹配的时候留下右表中的数据,而左表中的数据以NULL填充例:使用右外连接,把没有

SQL两表关联查询&批量修改字段值

SQL关联查询&修改字段,正确范例如下: --批量修改报告单位名称&更新时间 --tt和tp两表关联查询,将符合条件的tt表中的principal字段更新到tp表的ruperson字段 merge into nhis34.t_publicplaces tp using standard.t_organization tt on (tt.orgcode = tp.r_orgcode and tp.create_time > '2015-05-07 00:00:00') when mat

Mybatis高级查询之关联查询

3 关联查询 做查询之前,先修改几个配置.mapper.xml是在mybatis-config.xml中指定,那么我们每增加一个mapper都要增加一个配置,很麻烦.为了简化配置.需要将mapper接口和mapper.xml放到同一个文件下,并且接口和xml文件命名一致.使用mybatis的自动扫描:.这样,当我们新增接口的时候,直接创建接口和对应xml文件就可以了: <mappers> <!--<mapper resource="com.test.mapper.dao/

[NHibernate]一对多关系(关联查询)

目录 写在前面 文档与系列文章 一对多查询 总结 写在前面 上篇文章介绍了nhibernate的一对多关系如何配置,以及级联删除,级联添加数据的内容.这篇文章我们将学习nhibernate中的一对多关系的关联查询.前面文章中也介绍的nhibernate的查询:HQL,条件查询,原生SQL查询. 文档与系列文章 [Nhibernate]体系结构 [NHibernate]ISessionFactory配置 [NHibernate]持久化类(Persistent Classes) [NHibernat