mysql基础知识理解和sql题讲解分析面试实战(二)之join

Wesley13
• 阅读 649

mysql基础知识理解和sql题讲解分析面试实战(一)之join

  • join 的作用
  • left join ,right join ,innerjoin 的区别

实例讲解

  • 有个人员表(tab_person),项目表(tab_item) ,关联表(tab_person_item)

  • question:查询人员中选了项目表中的项目为oa的人员的id,和姓名

: step 1 : 创建主表和子表

--关联表的学习,创建主表tab_person,再创建项目表tab_item CREATE table tab_person( person_id int(5), person_name varchar(10), person_depart_id int(3), person_del_flag char(1), PRIMARY key(person_id) )

create table tab_item( item_id int(5), item_name varchar(20), item_del_flag char(1), PRIMARY key(item_id) )

--创建子表 -注意关联表的创建

CREATE table tab_person_item( person_id int(5), item_id int(5), FOREIGN key(person_id) REFERENCES tab_person(person_id) on DELETE CASCADE, FOREIGN key(item_id) REFERENCES tab_item(item_id) on DELETE CASCADE )

step 2: 插入数据
--插入主表数据
>insert into tab_person VALUES(1,'zhang3',1,'A'),(2,'zhang4',2,'A'),(3,'zhang5',1,'B'),(4,'zhang6',2,'B');
insert into tab_item values(1,'oa','d'),(2,'dt','e'),(3,'ga','f');

--插入子表数据

>insert INTO tab_person_item VALUES(1,1),(1,2),(2,3),(4,3),(3,2);

#### 查询
--问题 查询人员中选了项目表中的项目为oa的中关村人员的id,和姓名
-- 方法一 分开查询 
~~~ sql
select tab_person.person_id,tab_person.person_name from tab_person join (select tab_person_item.person_id from tab_item join tab_person_item on tab_item.item_name='oa' 
and tab_item.item_id=tab_person_item.item_id) t on t.person_id = tab_person.person_id  ;

-- 方法二 组合查询

select tab_person.person_id,tab_person.person_name from tab_person,tab_item,tab_person_item where tab_item.item_name='oa'  
and tab_item.item_id=tab_person_item.item_id and tab_person_item.person_id = tab_person.person_id

-- 结果

mysql基础知识理解和sql题讲解分析面试实战(二)之join

join 的用处

  • 将多个表连接在一块进行查询

  • 使用join,不需要加条件

    select count(*) from tab_person join tab_person_item

  • 使用right join 和left join 需要加条件也就是on 否则包语法错误 -- 在关联表里删除了一行id=4

    select * from tab_person left join tab_person_item ON tab_person_item.person_id = tab_person.person_id

mysql基础知识理解和sql题讲解分析面试实战(二)之join 具体区别看图

mysql基础知识理解和sql题讲解分析面试实战(二)之join

写的不好,欢迎拍砖,交流QQ群:181666459

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Easter79 Easter79
3年前
sql注入
反引号是个比较特别的字符,下面记录下怎么利用0x00SQL注入反引号可利用在分隔符及注释作用,不过使用范围只于表名、数据库名、字段名、起别名这些场景,下面具体说下1)表名payload:select\from\users\whereuser\_id1limit0,1;!(https://o
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
3年前
Android蓝牙连接汽车OBD设备
//设备连接public class BluetoothConnect implements Runnable {    private static final UUID CONNECT_UUID  UUID.fromString("0000110100001000800000805F9B34FB");
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(